DWR的配置文件(4)---Signatures in dwr.xml

DWR的配置文件(4)---Signatures in dwr.xml

Signatures部分用于配置Collections中装载对象元素的类型.举个例子来说:下面的java代码没有办法对List集合中的对象进行转换.

public class Check

{

public void setLotteryResults(List nos)

{

      ...

}

}

Singatures配置允许我们对DWR要操作的对象类型进行配置.对于了解JDK5泛型编程的开发人员来说下面的格式是很容易理解的.

<signatures>

<![CDATA[

import java.util.List;

import com.example.Check;

Check.setLotteryResults(List<Integer> nos);

]]>

</signatures>

DWR有个专门用于解析上面配置语句的解析器,虽然上面的是JDK5中才有的特性,因为有解析器的原因这也可以应用与JDK5之前的版本.

解析规则是不可见的,但有两种例外情况.

一种情况是因为DWR1.0的解析器中有个Bug,在有些场合会无法处理返回值的类型.所以应该要避免这种情况的发生.

一种情况是因为解析器是一个语法宽松的解析器,他不象编译器一样对语法有非常严格的要求,所有有时可能一些重要的语句没有配置而无法事先发现.

<signatures>

<![CDATA[

import java.util.List;

Check.setLotteryResults(List<Integer>);

]]>

</signatures>

DWR的将来版本可能会采用符合java官方规范的解析器,这样可以避免许多出错的情况.

Signature部分只用于泛型参数到基本类型参数的转换,对于其他的类型DWR采用反射机制或运行时类型来确定.在没有泛型参数的情况下可以不配置Signature.

public void method(String p);

public void method(String[] p);

下面的就需要配置,因为反射机制无法完成次类功能.

public void method(List<Date> p);

public void method(Map<String, WibbleBean> p);

下面可以不用配置,DWR可以自动完成转换.

public void method(List<String> p);

public void method(Map<String, String> p);

下面可以不用设置,DWR可以采用运行时转换.

public List<Date> method(String p);

有一个值得注意的地方是在javascript中所有对象的keys都是一个字符串,你也可以把其他对象作为keys.他们在使用之前都会转换成字符串形式.DWR1.x将采用这个特性来转换成String.以后对象的转换将会在服务器端完成.

你可能感兴趣的:(JavaScript,编程,xml,应用服务器,DWR)