DWR 框架怎么返回对象

363922298 贡献于2012-11-08

作者 denghaiping  创建于2009-09-15 07:10:00   修改者*  修改于2012-01-04 07:21:00字数14763

文档摘要:标签中指定javascript中可以访问的java类,并定义DWR应当如何获得要进行远程的类的实例。creator="new"属性指定java类实例的生成方式,new意味着DWR应当调用类的默认构造函数来获得实例,其他的还有spring方式,通过与IOC容器Spring进行集成来获得实例等等。
关键词:

 查看文章   DWR如何获得返回对象 list Map Set list.add(JavaBean) 1 2009-05-11 14:23 1、调用没有返回值和参数的JAVA方法 1.1、dwr.xml的配置 标签中包括可以暴露给javascript访问的东西。 标签中指定javascript中可以访问的java类,并定义DWR应当如何获得要进行远程的类的实例。creator="new"属性指定java类实例的生成方式,new意味着DWR应当调用类的默认构造函数来获得实例,其他的还有spring方式,通过与IOC容器Spring进行集成来获得实例等等。javascript=" testClass "属性指定javascript代码访问对象时使用的名称。 标签指定要公开给javascript的java类名。 标签指定要公开给javascript的方法。不指定的话就公开所有方法。 标签指定要防止被访问的方法。 1.2、javascript中调用 首先,引入javascript脚本 其中TestClass.js是dwr根据配置文件自动生成的,engine.js和util.js是dwr自带的脚本文件。 其次,编写调用java方法的javascript函数 Function callTestMethod1(){ testClass.testMethod1(); } 2、调用有简单返回值的java方法 2.1、dwr.xml的配置 配置同1.1 2.2、javascript中调用 首先,引入javascript脚本 其次,编写调用java方法的javascript函数和接收返回值的回调函数 Function callTestMethod2(){ testClass.testMethod2(callBackFortestMethod2); } Function callBackFortestMethod2(data){ //其中date接收方法的返回值 //可以在这里对返回值进行处理和显示等等 alert("the return value is " + data); } 其中callBackFortestMethod2是接收返回值的回调函数 3、调用有简单参数的java方法 3.1、dwr.xml的配置 配置同1.1 3.2、javascript中调用 首先,引入javascript脚本 其次,编写调用java方法的javascript函数 Function callTestMethod3(){ //定义要传到java方法中的参数 var data; //构造参数 data = “test String”; testClass.testMethod3(data); } 4、调用返回JavaBean的java方法 4.1、dwr.xml的配置 标签负责公开用于Web远程的类和类的方法,标签则负责这些方法的参数和返回类型。convert元素的作用是告诉DWR在服务器端Java 对象表示和序列化的JavaScript之间如何转换数据类型。DWR自动地在Java和JavaScript表示之间调整简单数据类型。这些类型包括Java原生类型和它们各自的封装类表示,还有String、Date、数组和集合类型。DWR也能把JavaBean转换成JavaScript 表示,但是出于安全性的原因,要求显式的配置,标签就是完成此功能的。converter="bean"属性指定转换的方式采用JavaBean命名规范,match=""com.dwr.TestBean"属性指定要转换的javabean名称,标签指定要转换的JavaBean属性。 4.2、javascript中调用 首先,引入javascript脚本 其次,编写调用java方法的javascript函数和接收返回值的回调函数 Function callTestMethod4(){ testClass.testMethod4(callBackFortestMethod4); } Function callBackFortestMethod4(data){ //其中date接收方法的返回值 //对于JavaBean返回值,有两种方式处理 //不知道属性名称时,使用如下方法 for(var property in data){ alert("property:"+property); alert(property+":"+data[property]); } //知道属性名称时,使用如下方法 alert(data.username); alert(data.password); } 其中callBackFortestMethod4是接收返回值的回调函数 5、调用有JavaBean参数的java方法 5.1、dwr.xml的配置 配置同4.1 5.2、javascript中调用 首先,引入javascript脚本 其次,编写调用java方法的javascript函数 Function callTestMethod5(){ //定义要传到java方法中的参数 var data; //构造参数,date实际上是一个object data = { username:"user", password:"password" } testClass.testMethod5(data); } 6、调用返回List、Set或者Map的java方法 6.1、dwr.xml的配置 配置同4.1 注意:如果List、Set或者Map中的元素均为简单类型(包括其封装类)或String、Date、数组和集合类型,则不需要标签。 6.2、javascript中调用(以返回List为例,List的元素为TestBean) 首先,引入javascript脚本 其次,编写调用java方法的javascript函数和接收返回值的回调函数 Function callTestMethod6(){ testClass.testMethod6(callBackFortestMethod6); } Function callBackFortestMethod6(data){ //其中date接收方法的返回值 //对于JavaBean返回值,有两种方式处理 //不知道属性名称时,使用如下方法 for(var i=0;i ); ]]> 标签是用来声明java方法中List、Set或者Map参数所包含的确切类,以便java代码作出判断。 7.2、javascript中调用(以返回List为例,List的元素为TestBean) 首先,引入javascript脚本 其次,编写调用java方法的javascript函数 Function callTestMethod7(){ //定义要传到java方法中的参数 var data; //构造参数,date实际上是一个object数组,即数组的每个元素均为object data = [ { username:"user1", password:"password2" }, { username:"user2", password:" password2" } ]; testClass.testMethod7(data); } 注意: 1、对于第6种情况,如果java方法的返回值为Map,则在接收该返回值的javascript回调函数中如下处理: function callBackFortestMethod(data){ //其中date接收方法的返回值 for(var property in data){ var bean = data[property]; alert(bean.username); alert(bean.password); } } 2、对于第7种情况,如果java的方法的参数为Map(假设其key为String,value为TestBean),则在调用该方法的javascript函数中用如下方法构造要传递的参数: function callTestMethod (){ //定义要传到java方法中的参数 var data; //构造参数,date实际上是一个object,其属性名为Map的key,属性值为Map的value data = { "key1":{ username:"user1", password:"password2" }, "key2":{ username:"user2", password:" password2" } }; testClass.testMethod(data); } 并且在dwr.xml中增加如下的配置段 ); ]]> 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中。 ====================================================================================== 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中这样使用: ...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对象的结构是这样的: public Person { private String name; private int 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不会向它传递任何参数。 DWR util.js 整理(DWR 处理各种form表单Select/option,table等,List,Bean(2) 2009年04月24日 星期五 下午 04:50 /********************************************************************************/ /***********************QQ: 171505924 Gump **************************************/ /********************************************************************************/    4、getText 取得text属性值             DWRUtil.getText(id): 用来获得 option 中的文本       比如: Java代码 1.                 调用 DWRUtil.getText("select"); 将返回 "香蕉" 字段;       DWRUtil.getText(id);仅仅是用来获得 select 文本值,其他不适用。    /******************************************************************************/    /******************************************************************************/    /******************************************************************************/    5、DWRUtil.getValue(id): 用来获得 form 表单值             有如下几种情况: Java代码 1.       Text area (id="textarea"): DWRUtil.getValue("textarea")将返回 Text area的值;    2. Selection list (id="select"): DWRUtil.getValue("select") 将返回 Selection list 的值;    3. Text input (id="text"): DWRUtil.getValue("text") 将返回 Text input 的值;    4. Password input (id="password"): DWRUtil.getValue("text") 将返回 Password input 的值;    5. Form button (id="formbutton"): DWRUtil.getValue("formbutton") 将返回 Form button 的值;    6. Fancy button (id="button"): DWRUtil.getValue("formbutton") 将返回 Fancy button 的值;   Text area (id="textarea"): DWRUtil.getValue("textarea")将返回 Text area的值; Selection list (id="select"): DWRUtil.getValue("select") 将返回 Selection list 的值; Text input (id="text"): DWRUtil.getValue("text") 将返回 Text input 的值; Password input (id="password"): DWRUtil.getValue("text") 将返回 Password input 的值; Form button (id="formbutton"): DWRUtil.getValue("formbutton") 将返回 Form button 的值; Fancy button (id="button"): DWRUtil.getValue("formbutton") 将返回 Fancy button 的值;    6、getValues 取得form多个值       批量获得页面表单的值,组合成数组的形式,返回 name/value;       例如: form(): Java代码 1.         2.          3.          4.          9.          10.          11.       那么: DWRUtil.getValues({textarea:null,select:null,text:null,password:null,button:null})    12.       将返回   ^^^^^^^^^^^^^^^^{textarea:1111,select:4444,text:2222,password:3333,button:5555}   那么: DWRUtil.getValues({textarea:null,select:null,text:null,password:null,button:null}) 将返回 ^^^^^^^^^^^^^^^^{textarea:1111,select:4444,text:2222,password:3333,button:5555}           7、DWRUtil.onReturn 防止当在文本框中输入后,直接按回车就提交表单。              8、DWRUtil.selectRange(ele, start, end);       在一个input box里选一个范围 Java代码 1. DWRUtil.selectRange("sel-test", $("start").value, $("end").value);    2.    3. 比如:    4.    5. DWRUtil.selectRange("sel-test", 2, 15);   DWRUtil.selectRange("sel-test", $("start").value, $("end").value); 比如: DWRUtil.selectRange("sel-test", 2, 15); 结果 文本框中的值"2345678901234"将被选中'    9、DWRUtil.setValue(id,value);       为指定的id元素,设置一个新值;    /******************************************************************************/    10、DWRUtil.setValues({ name: "fzfx88", password: "1234567890" }        ); 同上,批量更新表单值.    /******************************************************************************/    11、DWRUtil.toDescriptiveString()    带debug信息的toString,第一个为将要debug的对象,第二个参数为处理等级。等级如下:     0: Single line of debug 单行调试     1: Multi-line debug that does not dig into child objects 不分析子元素的多行调试     2: Multi-line debug that digs into the 2nd layer of child objects 最多分析到第二层子元素的多行调试         DWRUtil。toDescriptiveString("text",0);    /******************************************************************************/    12、DWRUtil.useLoadingMessage();     当发出ajax请求后,页面显示的提示等待信息; Java代码 1.     function searchUser(){    2. var loadinfo = "loading....."   3. try{    4.      regUser.queryAllUser(userList);    5.      DWRUtil.useLoadingMessage(loadinfo);            6. }catch(e){    7.    8. }    9.     }   利用DWR处理回调函数返回的list集合 2009-03-16 10:16 1、配置dwr.xml                             //为DWR实现类         //PO类            2、DWR类:StatusBusiness类 /** * 返回select框数据集合 * @param id * @param action * @return */ public List getSelectList(String id,String action){ //为文章结构清晰,以下代码省略 //此list为PO类user的集合 return list; } 3、PO类 public class User extends BasePO { private String id; private String name; //getter and setter } 4、AJAX:dwr处理 ...页面中
不可见Div
可见div
  在fireFox总image的宽度和长度都可以正常取到,但是在IE6中就出现如下现象: 1》将返回的str型html串加到body中已经有的div(可见)中可以取得img的宽度,但是动态构建一个div元素,然后在该div元素上取得img的宽度则取到的宽度=0 2》同在body中的div,一个是可见,一个是不可见,同样的方法,一个可以取到width,一个取得的width=0,我估计是隐藏的那个div中img标签还没有加载图片,故width=0   曾在网上看到别人这样的问题: JS获取图片的宽度和高度,然后根据这个数据判断,如果图片过大,就按比例缩小,如果在满足的范围内,就不做任何改动。 但是,现在碰到个问题, 就是获取图片地址后 。 var image = new Image(); image.src = picUrl; 这样以后, 如果我直接使用image.width和image.height都是0 但是,如果我先用alert(image.src); 这样之后,再使用image.width和image.height,这样就能获得准确的图片的高度和宽度了。 解决方案是: 于是我觉得图片的宽度只有图片在加载完毕后才可以取到,如果
中的话,它是不会加载图片的。  

下载文档到电脑,查找使用更方便

文档的实际排版效果,会与网站的显示效果略有不同!!

需要 3 金币 [ 分享文档获得金币 ] 0 人已下载

下载文档