DWR3.0簡單使用

DWR做爲一個優秀的服務器端ajax框架。特色是很是突出的。3.0版又增長了一些新的功能。值得確定!

在應用中使用dwr實際上是很是簡單的。下面以一個極簡單的步驟來展示它的簡單性和實用性:

1、給應用增長對dwr的支持
一、將dwr.jar包放入應用的lib包下
二、配置web.xml
Java代碼   
  1.  <!-- 加入dwr的支持 -->  
  2.  <servlet>  
  3. <servlet-name>dwr-invoker</servlet-name>  
  4. <servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class>  
  5. <init-param>  
  6.     <param-name>debug</param-name>  
  7.     <param-value>true</param-value>  
  8. </init-param>  
  9.  </servlet>  
  10.   
  11.  <servlet-mapping>  
  12. <servlet-name>dwr-invoker</servlet-name>  
  13. <url-pattern>/dwr/*</url-pattern>  
  14.  </servlet-mapping>  

三、配置dwr.xml
在web.xml同目錄下配置一個dwr.xml文件。它的做用有點相似spring的applicationContext.xml。主要是將全部須要在頁面由腳本程序調用的java類配置進去。如:
Java代碼   收藏代碼
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 3.0//EN" "http://getahead.org/dwr/dwr30.dtd">  
  3.   
  4. <dwr>  
  5.   
  6.   <allow>  
  7. <!--dwr3提供的一個日誌審覈過濾器-->  
  8.     <filter class="org.directwebremoting.filter.AuditLogAjaxFilter"/>  
  9.   
  10. <!--這是我配置的一個演示類,javascript="Demo" 表示,我能夠在頁面中用Demo這個名稱指向DwrDemo這個java類,類中的方法能夠在前臺調用-->  
  11.     <create creator="new" javascript="Demo">  
  12.       <param name="class" value="cn.ibeans.demo.dwr.DwrDemo"/>  
  13.     </create>  
  14.   
  15.   
  16.     <!-- this is a bad idea for live, but can be useful in testing -->  
  17.     <convert converter="exception" match="java.lang.Exception"/>  
  18.     <convert converter="bean" match="java.lang.StackTraceElement"/>  
  19.   
  20.   </allow>  
  21.   
  22. </dwr>  


2、添加java類(被配置到dwr.xml中)
DwrDemo.java:
Java代碼   收藏代碼
  1. package cn.ibeans.demo.dwr;  
  2.   
  3. public class DwrDemo {  
  4.     public String getHello(String name){  
  5.         return name+" 你好!";  
  6.     }  
  7. }  


3、前臺頁面中使用dwr
dwr.jsp:
Java代碼   收藏代碼
  1. <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>  
  2. <%@ taglib prefix="s" uri="/struts-tags"%>  
  3.   
  4. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">  
  5. <html>  
  6.   <head>  
  7.     <title>Dwr Demo</title>  
  8.     <script type='text/javascript' src='${pageContext.request.contextPath}/dwr/engine.js'> </script>  
  9.     <script type='text/javascript' src='${pageContext.request.contextPath}/dwr/util.js'> </script>  
  10.     <script type='text/javascript' src='${pageContext.request.contextPath}/dwr/interface/Demo.js'> </script>  
  11. <script type="text/javascript">  
  12. //此函數中能夠調用java類的方法,除了java方法自己的參數外,還要將回調函數名做爲參數傳給java方法  
  13. function sayHello(name){  
  14.     Demo.getHello(name,dwrHandler);  
  15. }  
  16.   
  17. //這是dwr的一個回調函數,data參數即java方法getHello(String name)的返回值  
  18. function dwrHandler(data){  
  19.     alert(data);  
  20. }  
  21. </script>  
  22.   </head>  
  23.     
  24. <body>&nbsp;   
  25. <h1>Hello World!</h1>  
  26. <script type="text/javascript">  
  27. sayHello("張三");  
  28. </script>  
  29. </body>  
  30. </html>  
注:jsp文件中必須引入幾個js,它們都是隱含存在的,不用考慮它們在哪兒。其中engine.js和util.js是固定的。另外的一個js的名稱就是dwr.xml中配置的類名。這些js的路徑基本是:app_root/dwr/....模式的,必定要寫對。
相關文章
相關標籤/搜索