DWR中的JavaScript详解

 DWR根据dwr.xml生成和Java代码类似的Javascript代码。 相对而言Java同步调用,创建与Java代码匹配的Ajax远程调用接口需要实现Ajax的异步调用特性。 DWR通过引入回调函数来解决这个问题,当结果被返回时,DWR会调用这个函数。 有两种推荐的方式来使用DWR实现远程方法调用。可以通过把回调函数放在参数列表里,也可以把回调函数放到元数据对象里。
7.10.1 简单的回调函数
下面介绍简单的回调函数实现方法,首先创建一个Java类,代码如下:
public class SimpRemote {
public String getXMLData(int index)
{
...
}
}
这个类可以在Javascript中这样使用:
<script type='text/javascript' src='dwr/engine.js'></script>
<script type='text/javascript' src='dwr/interface/SimpRemote.js'></script>
<script type="text/javascript">
function handleGetData(str)
{
     alert(str);
}
SimpRemote.getXMLData(1, handleGetData);
</script>
其中1是Java方法getXMLData()的一个参数,此外也可以使用这种减缩格式:
SimpRemote.getXMLData(1, function(str) { alert(str); });
7.10.2 调用元数据对象
另外一种方法是通过使用“调用元数据对象”来指定回调函数和其他选项。上面的例子可以写成如下形式:
SimpRemote.getXMLData(1, {
callback:function(str) { alert(str); }
});
这种方法易于阅读,更重要的是可以指定额外的调用选项。 在回调函数的元数据中可以指定超时和错误的处理方式。例如:
SimpRemote.getXMLData(1, {
callback:function(str) { alert(str); },
timeout:2000, errorHandler:function(message) { alert("调用选项: " + message); }
});
7.10.3 查找回调函数
在有些情况下很难区分各种回调选项。例如:
Remote.method({ timeout:7 }, { errorHandler: func });
这两个参数之一是bean的参数,另一个是元数据对象,但是我们不能清楚的告诉DWR哪个是哪个bean的参数,那个是元数据对象。为了可以跨浏览器,可以假定null == undefined。 所以当前的判断规则是:
 如果第一个或最后一个是一个函数,那么它就是回调函数,没有元数据对象,并且其他参数都是Java的方法参数。
  另外,如果最后一个参数是一个对象,这个对象中有一个callback成员,并且它是个函数,那么这个对象就是元数据对象,其他的都是Java方法参数。
 另外,如果第一个参数是 null ,就假设没有回调函数,并且其他的都是Java方法参数。尽管如此,我们会检查最后一个参数是不是null,如果是就发出警告。
 最后如果最后一个参数是null,那么就没有callback函数。
7.10.4 创造一个与Java对象匹配的Javascript对象
为了创造一个与Java对象匹配的Javascript对象,首先创建一个供远程调用的类,实现代码如下:
public class GetRemoteUser {
public void setUser(User p)
{ this.User = p;
}
}
其中User类的代码如下:
public User {
private String name;
private int age;
private Date[] appointments;
// get和set方法 ...
}
这样就可以在Javascript中写成如下形式::
var user = {
name:"tfnew21", age:12, appointments:[ new Date(), new Date("1 Jan 2008") ] }; GetRemoteUser.setUser(user);
在Javascript没有出现的字段,在Java中就不会被设置。 因为setter都是返回“void”值,这样就不需要使用callback函数了。如果需要一个返回void的服务端方法,也可以添加上callback函数,但DWR不会向它传递任何参数。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值