DWR中文文档v0.9 06

 

第5章. DWR中的JavaScript简介
DWR根据dwr.xml生成和Java代码类似的Javascript代码。

 相对而言Java同步调用,创建与Java代码匹配的Ajax远程调用接口的最大挑战来至与实现Ajax的异步调用特性。

 DWR通过引入回调函数来解决这个问题,当结果被返回时,DWR会调用这个函数。 有两种推荐的方式来使用DWR实现远程方法调用。可以通过把回调函数放在参数列表里,也可以把回调函数放到元数据对象里。

当然也可以把回调函数做为第一个参数,但是不建议使用这种方法。因为这种方法在处理自动处理http对象时(查看"Alternative Method")上会有问题。这个方法主要是为向下兼容而存在的。
5.1 简单的回调函数
假设你有一个这样的Java方法:

Java代码 复制代码
  1. public class Remote {    
  2.    public String getData(int index) {   
  3.      ...    
  4.     }   
  5.  }  

 我们可以在Javascript中这样使用:

Java代码 复制代码
  1. <script type='text/javascript' src='[WEBAPP]/dwr/engine.js'></script>    
  2. <script type='text/javascript' src='[WEBAPP]/dwr/interface/Remote.js'>   
  3. </script>   
  4.  ……    
  5. <script type="text/javascript">   
  6.     function handleGetData(str) {   
  7.       alert(str);    
  8.     }    
  9.   
  10.     Remote.getData(42, handleGetData);   
  11.  </script>  

 42是Java方法getData()的一个参数。 此外你也可以使用这种减缩格式:

Java代码 复制代码
  1. Remote.getData(42, function(str) { alert(str); });  

  5.2 调用元数据对象
另外一种语法时使用"调用元数据对象"来指定回调函数和其他的选项。上面的例子可以写成这样:

Java代码 复制代码
  1. Remote.getData(42, {    
  2.     callback:function(str) { alert(str); }    
  3. });  

 这种方法有很多优点:易于阅读,更重要的指定额外的调用选项。 在回调函数的元数据中你可以指定超时和错误的处理方式。例如:

Java代码 复制代码
  1. Remote.getData(42, {    
  2.    callback:function(str) { alert(str); },    
  3.    timeout:5000,    
  4.    errorHandler:function(message) { alert("Oops: " + message); }    
  5. });  

 5.3 查找回调函数
有些情况下我们很难区分各种回调选项(记住,Javascript是不支持函数重载的)。例如:

Java代码 复制代码
  1. Remote.method({ timeout:3 }, { errorHandler:somefunc });  

 这两个参数之一是bean的参数,另一个是元数据对象,但是我们不能清楚的告诉DWR哪个是哪个。为了可以跨浏览器,我们假定null == undefined。 所以当前的情况,规则是:
 如果第一个或最后一个是一个函数,那么它就是回调函数,没有元数据对象,并且其他参数都是Java的方法参数。
 另外,如果最后一个参数是一个对象,这个对象中有一个callback成员,并且它是个函数,那么这个对象就是元数据对象,其他的都是Java方法参数。
 另外,如果第一个参数是 null ,我们就假设没有回调函数,并且其他的都是Java方法参数。尽管如此,我们会检查最后一个参数是不是null,如果是就发出警告。
 最后如果最后一个参数是null,那么就没有callback函数。
 另外,发出错误信号是个糟糕的请求格式。
 
5.4 创造一个与Java对象匹配的Javascript对象
假设你有这样的Java方法:

Java代码 复制代码
  1. public class Remote {    
  2.    public void setPerson(Person p) {    
  3.         this.person = p;    
  4.    }    
  5. }  

 Person对象的结构是这样的:

Java代码 复制代码
  1. public Person {    
  2.      private String name;    
  3.      private int age;   
  4.      private Date[] appointments;   
  5.      // getters and setters ...    
  6. }  

 那么你可以在Javascript中这样写:

Java代码 复制代码
  1. var p = {    
  2.    name:"Fred Bloggs",    
  3.    age:42,    
  4.    appointments:[ new Date(), new Date("1 Jan 2008") ]    
  5. };    
  6. Remote.setPerson(p);  

 在Javascript没有出现的字段,在Java中就不会被设置。 因为setter都是返回'void',我们就不需要使用callback函数了。如果你想要一个返回void的服务端方法的完整版,你也可以加上callback函数。很明显DWR不会向它传递任何参数。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值