dwr3.0的HELLOWORLD创建过程

淘二哥女装专业导购
http://www.tao2ge.com

//[email protected]
//http://www.jiqishu.com
2009-06-09

大概流程:1.web工程导包.2.建立javabean.3.用url检查你的类是否可用.4.在页面中引用http://localhost:8080/aaaa/dwr/这个页面里指写的js文件.再加上你的JS.再加上你的button.



这个URL是查看DWR的方法  http://localhost:8080/[YOUR-WEBAPP]/dwr/


新建WEB工程.导入DWR3.0的那个JAR包.
导入log4j所需要的包..(用DEMO里的LIB,全导进去好了.)




首先创建一个WEB应用程序工程. 接下来将dwr的包导入.

开始写个javabean吧.须有构造函数.
然后写dwr配置文件.指定三个地方.你写的类并指定它的路径.你对这个类赋于js对象的称呼.你是新建的方式. 指定该对象的生命周期.

接下来.我们在web.xml中配置servlet启动dwr工程.


我们进行测试http://localhost:8080/dwrTest/dwr/  (dwrTest是你的项目名,套上去就可以了.其它不变)
进入后发现一个链接.点击进去,看到我们写的方法.如getMyName()这个方法,那就ok了.表示我们配置和BEAN都写对了.如果没有就再检查.还有我们引用的LIB库是否OK.

然后我们进入默认的index.jsp页面.组装并调用这些已经写好的东西.
我们的可以把回调ajax写在index.jsp里.也可以把这个鬼回调写到单独的一个文件里.引入进来就可以了.
但是这个INDEX.JSP.如果要使用DWR完成回调.还需要把三个js文件导进来才行.
1.dwr/engine.js   2.dwr/util.js  3.interface/MyTest.js   这三个js文件.前两个是dwr包里的.<script type= ... src=..../>类似这样写的.
后一个是执行http://localhost:8080/dwrTest/dwr这个URL.点击上面的链接后,进入就可以看到需要引入三个URL的提示,下面显示的是可以测试的类和函数.....

2.定义一个sayHello的JS函数.这是个回调函数哦.

3.写上你的网页内容.如:显示姓名.然后触发sayHello();





发现已知产生过的错误:

1.<script language="javascript">
    function sayHello(){
         
          MyTest.getMyName(function(data){
   dwr.util.setValue("demo1",data);

});
}

解惑:这段js的根本目的就是要通过sayHello这个函数产生一个回调并将结果输出到demo1这个层上.

     这里产生的困惑主要有:a. function 拼写错误..呵呵..这个是个人原因吧.JS写的不够多.
                                b. MyTest.getMyName这是个什么东西? 这个MyTest不过是dwr.xml中那个javascript="MyTest"对它的定义.它的意思无非是说javascript调用时的对象名称.在这里指定一下.
                                c.function(data){
                                     dwr.util.setValue("demo1",data);
                                   }
                             这里是dwr包里定义的一个函数.它指定了把data输出到哪个标签上.当然.这个函数可以随便换的.也可以用任何JS语法表达.不一定非得吊死在DWR的的函数里.用innerHTML也可以的呀.
                                d.<input 里定义一个触发事件.然后由事件绑定到sayHello()函数.
                             
2.配置文件: dwr.xml里面定义了的是什么??它和web.xml有关联吗?
                    a. 首先在web.xml里需要定义一个servlet用来启动一个dwr的主程序.
                    b.然后在dwr.xml里需要定义的是需要让dwr创建的方法和类.以及js对象该用的名称.
                    c.貌似还可以指定你的对象的生命周期.scope操作区域.application.
                 



3.最后一部就是我们的BEAN了..
       一定要用JAVABEAN的方式创建.很多时候我们忽视了这一块.导致程序无法正常使用.
        JAVABEAN的有一个空的构造函数.这就对了.呵呵.
          然后再写别的方法.





源文件
com.arpenker.Test
package com.arpenker;

public class Test {

public Test(){
}

public String getMyName(){  
        return "hangzhou--arpenker";  
    }  

}



dwr.xml和web.xml放一块啊.
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 1.0//EN" "http://www.getahead.ltd.uk/dwr/dwr10.dtd">
<dwr>
<allow>
<create creator="new" javascript="MyTest" scope="application">
<param name="class" value="com.arpenker.Test"/>
</create>
</allow>
</dwr>

 

web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4"
xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
 
  <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>
 
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
</web-app>


index.jsp
<%@ page language="java" contentType="text/html; charset=GB18030"
  pageEncoding="GB18030"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GB18030">
<title>DWR - Test Home</title>



<script type='text/javascript' src='/dwrTest/dwr/engine.js'></script>
<script type='text/javascript' src='/dwrTest/dwr/util.js'></script>
<script type='text/javascript' src='/dwrTest/dwr/interface/MyTest.js'></script>


<script language="javascript">
    function sayHello(){
   
    MyTest.getMyName(function(data){
   
    dwr.util.setValue("demo1",data);
    });
   
    }
   
   
</script>
</head>
<body>
    <h1>arpenker dwr3.0 helloworld 精讲.</h1>   
    <input type="button" value="显示姓名" onclick="sayHello()"/>  
    
    <div id="demo1" ></div>

</body>
</html>


还有几个包.dwr.jar log*****.jar把官方dwr3下载后里面有.实例里面那些包全加进来就行了.

有什么疑问?
//[email protected]
//http://www.jiqishu.com

你可能感兴趣的:(JavaScript,jsp,Web,DWR,Gmail)