AJax技术

ajax基础配置(4)

字号+ 作者:H5之家 来源:H5之家 2015-10-22 15:08 我要评论( )

3、由以上可以发现,对于java方法的返回值为List(Set)的情况,DWR将其转化为Object数组,传递个javascript;对于java方法的返回值为Map的情况,DWR将其转化为一个Object,其中Object的属性为原Map的key值,属性值为


3、由以上可以发现,对于java方法的返回值为List(Set)的情况,DWR将其转化为Object数组,传递个javascript;对于java方法的返回值为Map的情况,DWR将其转化为一个Object,其中Object的属性为原Map的key值,属性值为原Map相应的value值。
4、如果java方法的参数为List(Set)和Map的情况,javascript中也要根据3种所说,构造相应的javascript数据来传递到java中。 

小结:如果javascript中返回的是list,然后再马上调用一个要list参数的java方法,则不用封装,直接用谅可以了

如:

function delByPsw2(){   
      var getPsw =$("addtext2").value;
      test.findByPsw(getPsw,del4);   //返回一个List
     }
     
     function del4(data){     //data为list
      var da;
      da=[
       {name:data[0].name,psw:data[0].psw},
       {name:data[1].name,psw:data[1].psw}
      ];
      test.del3(data,callback4);    //可以不封装,直接用
     }
     
     function callback4(data){
      alert(data);
     }

 

======================================================================================

Scripting Introduction

DWR根据dwr.xml生成和Java代码类似的Javascript代码。

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

DWR通过引入回调函数来解决这个问题,当结果被返回时,DWR会调用这个函数。

有两种推荐的方式来使用DWR实现远程方法调用。可以通过把回调函数放在参数列表里,也可以把回调函数放到元数据对象里。

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

简单的回调函数

假设你有一个这样的Java方法:

public class Remote { public String getData(int index) { ... } }

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

<script type="text/javascript" src="[WEBAPP]/dwr/interface/Remote.js"> </script> <script type="text/javascript" src="[WEBAPP]/dwr/engine.js"> </script> ...function handleGetData(str) { alert(str); } Remote.getData(42, handleGetData);

42是Java方法getData()的一个参数。

此外你也可以使用这种减缩格式:

Remote.getData(42, function(str) { alert(str); });

调用元数据对象(Meta-Data)

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

Remote.getData(42, { callback:function(str) { alert(str); }});

这种方法有很多优点:易于阅读,更重要的指定额外的调用选项。

超时和错误处理

在回调函数的元数据中你可以指定超时和错误的处理方式。例如:

Remote.getData(42, { callback:function(str) { alert(str); }, timeout:5000, errorHandler:function(message) { alert("Oops: " + message); }});

查找回调函数

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

Remote.method({ timeout:3 }, { errorHandler:somefunc });

这两个参数之一是bean的参数,另一个是元数据对象,但是我们不能清楚的告诉DWR哪个是哪个。为了可以跨浏览器,我们假定null == undefined。 所以当前的情况,规则是:

  • 如果第一个或最后一个是一个函数,那么它就是回调函数,没有元数据对象,并且其他参数都是Java的方法参数。
  • 另外,如果最后一个参数是一个对象,这个对象中有一个callback成员,并且它是个函数,那么这个对象就是元数据对象,其他的都是Java方法参数。
  • 另外,如果第一个参数是 null ,我们就假设没有回调函数,并且其他的都是Java方法参数。尽管如此,我们会检查最后一个参数是不是null,如果是就发出警告。
  • 最后如果最后一个参数是null,那么就没有callback函数。
  • 另外,发出错误信号是个糟糕的请求格式。
  • 创造一个与Java对象匹配的Javascript对象

    假设你有这样的Java方法:

    public class Remote { public void setPerson(Person p) { this.person = p; }}

    Person对象的结构是这样的:

    age; private Date[] appointments; // getters and setters ...}

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

    var p = { name:"Fred Bloggs", age:42, appointments:[ new Date(), new Date("1 Jan 2008") ]};Remote.setPerson(p);

    在Javascript没有出现的字段,在Java中就不会被设置。

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

     

     

    1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

    相关文章
    • 猿代码 更接地气的线上IT技术精讲平台

      猿代码 更接地气的线上IT技术精讲平台

      2016-01-17 18:01

    • 利用AjaxControlToolkit实现百度搜索时的下拉列表提示详细步骤

      利用AjaxControlToolkit实现百度搜索时的下拉列表提示详细步骤

      2016-01-17 14:13

    • “.NET技术”Ajax和WEB服务数据格式:自定义返回格式

      “.NET技术”Ajax和WEB服务数据格式:自定义返回格式

      2016-01-15 15:23

    • 简述jQuery ajax的执行顺序

      简述jQuery ajax的执行顺序

      2016-01-15 15:21

    网友点评