枫林在线论坛>>技术交流 [管理模式] [快速回复] [推荐给朋友]
[382559] 主题: DWR让Ajax如此简单(1)
作者: little 标题:  DWR让Ajax如此简单(1)[转载]
昵称: 渺小 来自: 192.168.*.* 详细
经验值: 14318 发贴时间: 2005年12月17日 11:22:04
等级: 博大精深 长度: 3623字
http://searchwebservices.techtarget.com.cn/tips/261/2183761.shtml 

DWR让Ajax如此简单

【2005-11-07 14:10】【】【Matrix】  

Ajax,或者说是异步JavaScript和XML,描述了一种使用混合了HTML(或XHTML)和层叠样

式表作为表达信息,来创建交互式的Web应用的开发技术;文档对象模型(DOM),JavaScri
p
t,动态地显示和与表达信息进行交互;并且,XMLHttpRequest对象与Web服务器异步地交

换和处理数据。

  因特网上许多例子展示了在一个HTML文件内部使用XMLHttpRequest与服务器端进行

交互的必要的步骤。当手工地编写和维护XMLHttpRequest代码时,开发者必须处理许多

潜在的问题,特别是类似于跨浏览器的DOM实现的兼容性这样的问题。这将会导致在编码

和调试Javascript代码上面花费数不清的时间,这显然对开发者来说很不友好。

  DWR(直接Web远程控制)项目是在Apache许可下的一个开源的解决方案,它供给那些

想要以一种简单的方式使用Ajax和XMLHttpRequest的开发者。它具有一套Javascript功

能集,它们把从HTML页面调用应用服务器上的Java对象的方法简化了。它操控不同类型

的参数,并同时保持了HTML代码的可读性。

  DWR不是对一个设计的插入,也不强迫对象使用任何种类的继承结构。它和servlet

框架内的应用配合的很好。对缺少DHTML编程经验的开发者来说,DWR也提供了一个Java
S
cript库包含了经常使用的DHTML任务,如组装表,用item填充select下拉框,改变HTML

元素的内容,如<div>和<span> 


  DWR网站是详尽的并且有大量的文档,这也是这篇文章的基础。一些例子用来展示D
W
R如何使用和用它的库可以完成什么样的工作。

  这篇文章让读者看到了一个使用了DWR的Web应用是如何一步步建立的。我会展示创

建这个简单的示例应用的必要的细节,这个应用是可下载的并且可以在你的环境中布署

来看看DWR如何工作。

  注意:找到有关Ajax的信息并不困难;网页上有几篇文章和博客的条目涵盖了这个主

题,每一个都试图指出和评论这个概念的不同的方面。在资源部分,你会找到一些有趣

的指向示例和文章的链接,来学习Ajax的更多的内容。

  示例应用

  这篇文章使用的示例应用模拟了多伦多的一个公寓出租搜索引擎。用户可以在搜索

前选择一组搜索标准。为了提高交互性,Ajax中以下两种情况下使用:

  ·应用通告用户配合他的选择会返回多少搜索结果。这个数字是实时更新的-使用A
j
ax-当用户选择的卧室和浴室的数量,或者价格范围变化时。当符合标准的搜索结果没有

或太多时,用户就没有必要点击搜索按纽。

  ·数据库查询并取回结果是由Ajax完成的。当用户按下显示结果按钮时,数据库执

行搜索。这样,应用看起来更具响应了,而整个页面不需要重载来显示结果。

  数据库

  我们使用的数据库是HSQL,它是一种占用资源很小的Java SQL数据库引擎,可以不

需要安装和配置的与Web应用捆绑在一起。一个SQL文件被用来在Web应用的上下文启动时

创建一个内存中的表并添加一些记录。

  Java类

  应用包含了两个主要的类叫Apartment和ApartmentDAO。Apartment.java类是一个有

着属性和getter/setter方法的简单的Java类。ApartmentDAO.java是数据访问类,用来

查询数据库并基于用户的搜索标准来返回信息。ApartmentDAO类的实现的直接了当的;它

直接使用了Java数据库联接调用来得到公寓的总数和符合用户请求的可用公寓的列表。


  DWR配置和使用

  设置DWR的使用是简单的:将DWR的jar文件拷入Web应用的WEB-INF/lib目录中,在we
b
.xml中增加一个servlet声明,并创建DWR的配置文件。DWR的分发中需要使用一个单独的

jar文件。你必须将DWR servlet加到应用的WEB-INF/web.xml中布署描述段中去。

    <servlet>
        <servlet-name>dwr-invoker</servlet-name>
        <display-name>DWR Servlet</display-name>
        <description>Direct Web Remoter Servlet</description>
        <servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-clas
s>
        <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>

========== * * * * * ==========
Top

| 用户注册 | 在线用户 | 投票中心 | 常见问题 |

Copyright © 2001-2012 枫林在线(www.FengLin.info) All Rights Reserved
页面运行使用43.3毫秒