dwr使用步骤
一:基本步骤:
1.为工程添加jar包:dwr.jar common-logging.jar
如果本工程使用struts,则struts内置了common-logging.jar,不需要重复引入
2.web.xml部分,添加dwr的servlet配置
<servlet>
<servlet-name>dwr-invoker</servlet-name>
<servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class>
<init-param>
<param-name>debug</param-name>
<param-value>true</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>dwr-invoker</servlet-name>
<url-pattern>/dwr/*</url-pattern>
</servlet-mapping>
注意:
<init-param>
<param-name>debug</param-name>
<param-value>true</param-value>
</init-param>
该配置项是开启dwr控制台的开关,如果该项为false,则dwr控制台失效.
3.在/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="test">
<param name="class" value="test.TestDao" />
</create>
<!-- 如果需要实体类,则需要配置为如下 match:类路径 converter="bean":固定参数 -->
<convert match="bean.*" converter="bean"></convert>
</allow>
</dwr>
注意:creator="new" 代表本类的创建方式
javascript="test" 代表本类在javascript中的名称
name="class" 代表把某个类配置到dwr中 value="":代表类路径
4.建立相关的类:
package test;
public class TestDao {
public void hello(){
System.out.println("Hello JavaScript . . .");
}
public void sayHello(String name){
System.out.println("Hello " + name);
}
public int add(int a , int b){
return a+b;
}
}
5.把工程部署到tomcat中,通过下列地址测试dwr环境是否完成:
http://ip:port/appName/dwr
如果看到控制台,点击进入,测试方法是否可以正常运行
6.在需要调用dwr相关资源的页面中,按照控制台的提示cope资源:
<script type='text/javascript' src='${pageContext.request.contextPath }/dwr/interface/test.js'></script>
<script type='text/javascript' src='${pageContext.request.contextPath }/dwr/engine.js'></script>
7.调用dwr资源的脚本写法:
dwr名称.方法名称(参数... ,{
callback:function(返回值){
处理返回的逻辑块
}
})
例如:
test.hello();
test.sayHello("诡异小孩");
test.add(10,10,{
callback:function(data){
alert(data);
}
});
test.add(10,10,callback);
function callback(data){
alert(data);
}
二:基本应用:
返回数据解析:
1.简单对象:
test.getTest({
callback:function(data){
alert(data.id+":"+data.name+":"+data.age+":"+data.sex+":"+data.birthday);
}
});
2.简单列表:
test.queryForList({
callback:function(data){
for(var i=0;i<data.length;i++){
alert(data[i]);
}
}
});
3.对象列表:
test.queryAll({
callback:function(data){
for(var i=0;i<data.length;i++){
alert(data[i].id+":"+data[i].name+":"+data[i].age+":"+data[i].sex+":"+data[i].birthday);
}
}
});
4.向后台传对象:
var myObject={'id':108,'name':'小
白','age':24,'sex':'女','birthday':'1989-11-01'};
test.setObject(myObject);
参数解析:
preHook:交互结束之前执行
callback:交互结束之后返回
postHook:在返回结束之后执行
timeout:设置响应超时时间
errorHandler:设置异常捕获
test.query({
callback:function(data){alert("处理返回"+data);},
preHook:function(){alert("返回之前...");},
timeout:4000,
errorHandler:function(msg){alert("如果响应时间超过timeout的值,则服务器超时...");}
});
dwr使用步骤的更多相关文章
- DWR入门教程
DWR(Direct Web Remoting)是一个WEB远程调用框架.利用这个框架可以让AJAX开发变得很简单.利用DWR可以在客户端利用JavaScript直接调用服务端的Java方法并返回值给 ...
- DWR入门的例子(一个)
DWR(Direct Web Remoting)是WEB远程调用框架.使用这种框架使AJAX发展至今已成为非常easy.使用DWR能client利用JavaScript直接调用服务端的Java方法并返 ...
- DWR组件——基于远程过程调用实现Ajax
转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6686115.html 一:DWR的用途 DWR(Direct Web Remoting)是一个Web远程调用 ...
- [JavaEE] DWR入门教程
DWR(Direct Web Remoting)是一个WEB远程调用框架.利用这个框架可以让AJAX开发变得很简单.利用DWR可以在客户端利用JavaScript直接调用服务端的Java方法并返回值给 ...
- DWR实现扫一扫登录功能
前言 <DWR实现后台推送消息到Web页面>一文中已对DWR作了简介,并列出了集成步骤.本文中再一次使用到DWR,用以实现扫一扫登录功能. 业务场景 web端首页点击"登陆&qu ...
- 基于注解的DWR使用
dwr3.0支持使用注解,如果不喜欢配置dwr.xml文件,注解是个不错的方法,简单快捷. 步骤如下: 1.配置web.xml文件,需要在DwrServlet里加classes初始化参数: <i ...
- 有关dwr推送的笔记
想做一个web推送相关的东东,昨天搞了一天,终于把这些杂乱的配制弄清了,今天写出来方便以后记住,也方便大家看一下吧 1:引入dwr包,我用的是maven <dependency> < ...
- DWR基本配置
DWR——Direct Web Remoter Servlet 供给那些想要以一种简单的方式使用Ajax和XMLHttpRequest的开发者.它具有一套JavaScript功能集,它们把从HTML页 ...
- 采用DWR、maven保存数据到数据库
一.原理: Ajax是时下比较流行的一种web界面设计新思路,其核心思想是从浏览器获取XMLHttp对象与服务器端进行交互. DWR(Direct Web Remoting)就是实现了这种Ajax技术 ...
随机推荐
- BZOJ 2442 修剪草坪
NOIP的时候一定要看清楚数据范围. #include<iostream> #include<cstdio> #include<cstring> #include& ...
- 安装webmin
wget http://nchc.dl.sourceforge.net/project/webadmin/webmin/1.740/webmin-1.740.tar.gz 解压缩文件,命令是:tar ...
- 使用Office 365 试用账户 体验Office 365功能
首先,需要申请Office 365 Enterprise E3版本的试用账户. 在浏览器中,输入以下地址,然后回车: http://products.office.com/en-us/business ...
- ERROR 1130: Host ’...′ is not allowed to connect to this MySQL server
/******************************************************************** * ERROR 1130: Host ’...′ is no ...
- JSONP解决ajax跨域问题
在A域名下,用ajax请求B域名下的请求,会报类似这样的错误:No 'Access-Control-Allow-Origin' header is present on the requested r ...
- ANTLR3完全参考指南读书笔记[08]
前言 不要让用户被那些“专业术语”吓住! 用心设计的提示和反馈信息是软件设计者的“职业良心”. 内容 1 存在哪些错误? 2 美化错误提示 3 错误恢复策略 1 存在哪些错误? 在DSL语言开 ...
- dennis gabor 从傅里叶(Fourier)变换到伽柏(Gabor)变换再到小波(Wavelet)变换(转载)
dennis gabor 题目:从傅里叶(Fourier)变换到伽柏(Gabor)变换再到小波(Wavelet)变换 本文是边学习边总结和摘抄各参考文献内容而成的,是一篇综述性入门文档,重点在于梳理傅 ...
- tyvj 1056 能量项链 区间dp (很神)
P1056 能量项链 时间: 1000ms / 空间: 131072KiB / Java类名: Main 背景 NOIP2006 提高组 第一道 描述 在Mars星球上,每个Mars人都随身佩 ...
- html5的程序接口与元素变化
除了原先的DOM接口,HTML5增加了更多API,如:1. 用于即时2D绘图的Canvas标签2. 定时媒体回放3. 离线数据库存储4.文档编辑5. 拖拽控制6. 浏览历史管理元素变化新的解析顺序新的 ...
- php部分---函数、四类常用函数、例子(下拉菜单添加内容);
1.简单函数 四要素:返回类型,函数名,参数列表,函数体 function Show() { echo "hello"; } Show(); 2.有返回值的函数 function ...