DWR使用

前端之家收集整理的这篇文章主要介绍了DWR使用前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

第一步:下载DWR包。
从网站(http://directwebremoting.org/dwr/download)下载最新的dwr.jar包,放在你的Application的WEB-INF/lib目录下。
第二步:配置web.xml文件

在web.xml文件的<web-app></web-app>标签中,添加如下配置:

<servlet>
	<servlet-name>dwr-invoker</servlet-name>
	<servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class>
</servlet>
<servlet-mapping>
	<servlet-name>dwr-invoker</servlet-name>
	<url-pattern>/dwr/*</url-pattern>
</servlet-mapping>

第三步:配置dwr.xml文件
在你的Application的WEB-INF下新建dwr.xml文件内容如下:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN" "http://getahead.ltd.uk/dwr/dwr20.dtd">
<dwr>
  <allow>    
    <create creator="new" javascript="Pict" scope="application">
      <param name="class"  value="bean.Pict"/>
       <include method="method1" />
    </create>         
  </allow>
</dwr>
解释:
creator="new"属性指定java类实例的生成方式。"new"意味着DWR应该调用类的默认构造函数来获得类的实例,一般我们用这个就可以搞定了。当然还有其它的方式,目前我还没有用到,就不说了。
javascript="Pict"指定JavaScript代码访问Java对象的时候使用的名称
标签指定要公开给JavaScript的java类名
<include>标签指定要公开给JavaScript的方法,不指定的话公开所有的方法
第四步:在JS中调用
1. 引入JavaScript脚本

<script language="javascript1.2" src="dwr/interface/Pict.js"></script>
<script language="javascript1.2" src="dwr/util.js"></script>
<script language="javascript1.2" src="dwr/engine.js"></script>

其中第一个导入的标签脚本必须是手动写入,名字和<create>标签中的属性JavaScript的值相等,其后缀为.js。你只要在这里手动写入就可以了,实际由dwr根据配置文件自动生成内容。util.js和engine.js是dwr自带的脚本文件
2. 编写调用java方法的JS函数
比如:下面是一个没有参数,没有返回值的函数调用
Function callJava(){
   Pict.method1();
}
如果无参数,有返回值:

Function callJava(){
   Pict.method1(retu);//retu称之为回调函数,实际就是将返回值赋给了这个函数
}
Function retu(data){
   Alert(data);//这里的data的值才是实际上的方法method1的返回值。
}

如果有参数,也有返回值,可直接在方法中加入到回调函数的前面即可
总的来说,参数和回调函数都放在方法的括号中,遵循的原则是回调函数总是最后一个,有参数就往其前面写,没有就不用写了

基本上的用法如上,但还有一些细节,比如返回值是JavaBean,Map等,都需要进一步的配置

如果Java方法返回的是JavaBean,则要做以下调整
1.dwr.xml的配置增加了<convert>标签。dwr.xml全部代码如下

<dwr>
  <allow>     
    <create creator="new" javascript="testJavaclass" scope="application">
      <param name="class"  value="com.dwr.testJavaclass"/>
      <include method="testMethod" />
    </create>    
    <convert converter="bean" match="bean.DuanInfo" />        
  </allow>
</dwr>
convert 元素的作用是告诉DWR在服务器端Java对象表示和序列化的JavaScript之间如何转换数据类型。

一般将JavaBean转化为JavaScript中的对象类型。
convert=“bean” 属性指定要将JavaBean转换到JavaScript中。
match 属性指定要转换的JavaBean的完整路径名。
param 标签指定要转换的JavaBean的属性,此标签可省略,认为是转换所有属性
2.在JavaScript 中调用
调用没有改变,和(1)说的一样
3.对返回值的处理
此时我们将返回值看作是一个Object类型,因此在JavaScript中使用Object的用法调用。比如:
testJavaclass. testMethod(k,function(vector) {
	          if(vector == null || vector==[]) {
		         return;
	          }
 
	          for(var i =0 ; i<vector.length;i++) {
	            var a = vector[i].offsetX;
	            var b = vector[i].offsetY;
	          }
}
原文链接:https://www.f2er.com/ajax/165107.html

猜你在找的Ajax相关文章