DWR 入门教程
来源:互联网 发布:一键排版助手 for mac 编辑:程序博客网 时间:2024/05/02 05:45
什么是DWR(DirectWeb Remote)?
DWR是一种AJAX解决方案!
DWR包括一个java库,以及一套javascript,使得我们可以用一种非常简单的方式,在页面上使用javascript直接调用后台的java对象!
DWR架构
DWR的javascript库包括几个部分:dwr的javascript引擎(即对AJAX调用的封装)、 dwr提供的一些非常有用的辅助javascript函数库、 以及dwr自动帮我们生成的专门用于调用后台JavaBean方法的javascript库!
<scripttype="text/javascript"src="dwr/engine.js"></script>
<scripttype="text/javascript"src="dwr/util.js"></script>
<scripttype="text/javascript"src="dwr/interface/test1.js"></script>
Dwr在运行的时候,动态生成一个javascript库,这个库是对后台javabean调用的封装,我们可以直接使用这个库来实现直接调用JavaBean的目的!
注意:是在运行的时候动态生成!
下面我们来看看如何安装和使用(基于DWR2.x版本):
如何下载、安装与使用?
官方网址: http://getahead.org/dwr
1、 下载dwr.jar,将其加入web-inf/lib目录
2、 修改web.xml文件,添加DWRServlet的映射
<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>
3、 配置dwr,即在WEB-INF目录下,添加dwr.xml文件,让dwr知道在运行的时候应该给哪些JavaBean生成相应的javascript库!
<?xmlversion="1.0"encoding="UTF-8"?>
<!DOCTYPEdwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN" "http://getahead.org/dwr/dwr20.dtd">
<dwr>
<allow>
<createcreator="new"javascript="test1">
<paramname="class"value="com.bjsxt.dwr.Test1"/>
</create>
</allow>
</dwr>
这个配置的意思是,要创建的是Test1对象的javascript库,而且这个库的名字叫test1,同时,这也是我们在JSP页面上调用这个对象的时候所使用的名称,请看下面的JavaBean代码和JSP实例:
4、下面是Test1这个JavaBean的源代码:
package com.bjsxt.dwr;
public class Test1 {
public String sayHello(String name){
return "你好,"+name;
}
}
5、在JSP中的使用!
<%@ pagelanguage="java"contentType="text/html; charset=GB18030"
pageEncoding="GB18030"%>
<!DOCTYPEHTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<metahttp-equiv="Content-Type"content="text/html; charset=GB18030">
<scripttype="text/javascript"src="dwr/engine.js"></script>
<scripttype="text/javascript"src="dwr/util.js"></script>
<scripttype="text/javascript"src="dwr/interface/test1.js"></script>
<title>Insert title here</title>
<scripttype="text/javascript">
function sayHello(){
test1.sayHello("李四ddd",
function(data){
alert(data);
}
);
}
</script>
</head>
<body>
<a href="#" onclick="sayHello()">Test1</a>
</body>
</html>
让我们简单看一下这个JSP文件:首先引入DWR中的两个核心javascript库:engine.js和util.js,它们分别是dwr中的核心引擎库和辅助工具函数库!
第三个引入的dwr/interface/test1.js,实际上这个文件并不存在,这是由dwr在运行的时候动态生成的!test1这个名称,跟dwr.xml文件中配置的对应对象的javascript属性一致!
而且,我们在使用的时候,直接使用test1这个名称,作为这个对象的引用。直接调用这个对象的方法:sayHello,这个方法的名称必须与JavaBean中的方法名称一致!
sayHello方法有一个参数,同时返回一个值。我们可以直接传递参数,同时指定一个javascript函数来处理这个返回值(如上例所示)。
l 如何传递参数
n 如果要调用的方法有参数,则将参数放在前面
l 如何处理返回值
n 定义一个函数来处理返回值,这个函数有一个参数,就是JavaBean方法的返回值
DWR Javascript库中常用函数的使用
l 设置异步/同步模式
n 默认情况下,DWR以异步的方式跟服务器通信,即不同方法可以同时向服务器发送请求,如果想要改为同步的方式,可以调用:dwr.engine.setAsync(false);
l 获得对某个页面元素对象的引用
n $(“元素的ID或name”)
- DWR入门教程
- DWR入门教程
- DWR入门教程
- DWR入门教程
- DWR入门教程
- DWR入门教程
- DWR入门教程
- DWR入门教程
- DWR入门教程
- DWR入门教程
- DWR入门教程
- DWR入门教程
- DWR入门教程
- DWR入门教程
- DWR入门教程
- Dwr入门教程
- DWR入门教程
- DWR 入门教程
- erlang gen_server热更新
- GBDT(MART)迭代决策树入门教程|简介
- C++内存对象大会战
- altera FPGA学习日记
- 下载网页中视频
- DWR 入门教程
- 使用命令行创建Android项目
- 教你透彻了解红黑树
- hdu2795
- Linux命令学习之一
- 跟我一起写 Makefile
- mysql基本语法及面试常见问题
- 搜索 Seven Puzzle (AOJ 0121 bfs)
- Hadoop1.2.1 完全分布式集群搭建实操笔记