枫林在线论坛精华区>>技术交流
[382559] 主题: DWR让Ajax如此简单(1)
作者: little (渺小)
标题: DWR让Ajax如此简单(1)[转载]
来自: 192.168.*.*
发贴时间: 2005年12月17日 11:22:04
长度: 3623字
http://searchwebservices.techtarget.com.cn/tips/261/2183761.shtm


DWR让Ajax如此简单

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

Ajax,或者说是异步JavaScript和XML,描述了一种使用混合了HTML(或XH
TML)和层叠样
式表作为表达信息,来创建交互式的Web应用的开发技术;文档对象模型(DO
M),JavaScrip
t,动态地显示和与表达信息进行交互;并且,XMLHttpRequest对象与Web服
务器异步地交
换和处理数据。

  因特网上许多例子展示了在一个HTML文件内部使用XMLHttpRequest与
服务器端进行
交互的必要的步骤。当手工地编写和维护XMLHttpRequest代码时,开发者
必须处理许多
潜在的问题,特别是类似于跨浏览器的DOM实现的兼容性这样的问题。这将
会导致在编码
和调试Javascript代码上面花费数不清的时间,这显然对开发者来说很不
友好。

  DWR(直接Web远程控制)项目是在Apache许可下的一个开源的解决方案
,它供给那些
想要以一种简单的方式使用Ajax和XMLHttpRequest的开发者。它具有一套
Javascript功
能集,它们把从HTML页面调用应用服务器上的Java对象的方法简化了。它
操控不同类型
的参数,并同时保持了HTML代码的可读性。

  DWR不是对一个设计的插入,也不强迫对象使用任何种类的继承结构。
它和servlet
框架内的应用配合的很好。对缺少DHTML编程经验的开发者来说,DWR也提
供了一个JavaS
cript库包含了经常使用的DHTML任务,如组装表,用item填充select下拉
框,改变HTML
元素的内容,如<div>和<span> 


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

  这篇文章让读者看到了一个使用了DWR的Web应用是如何一步步建立的
。我会展示创
建这个简单的示例应用的必要的细节,这个应用是可下载的并且可以在你
的环境中布署
来看看DWR如何工作。

  注意:找到有关Ajax的信息并不困难;网页上有几篇文章和博客的条目
涵盖了这个主
题,每一个都试图指出和评论这个概念的不同的方面。在资源部分,你会
找到一些有趣
的指向示例和文章的链接,来学习Ajax的更多的内容。

  示例应用

  这篇文章使用的示例应用模拟了多伦多的一个公寓出租搜索引擎。用
户可以在搜索
前选择一组搜索标准。为了提高交互性,Ajax中以下两种情况下使用:

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

  ·数据库查询并取回结果是由Ajax完成的。当用户按下显示结果按钮
时,数据库执
行搜索。这样,应用看起来更具响应了,而整个页面不需要重载来显示结
果。

  数据库

  我们使用的数据库是HSQL,它是一种占用资源很小的Java SQL数据库
引擎,可以不
需要安装和配置的与Web应用捆绑在一起。一个SQL文件被用来在Web应用的
上下文启动时
创建一个内存中的表并添加一些记录。

  Java类

  应用包含了两个主要的类叫Apartment和ApartmentDAO。Apartment.j
ava类是一个有
着属性和getter/setter方法的简单的Java类。ApartmentDAO.java是数据
访问类,用来
查询数据库并基于用户的搜索标准来返回信息。ApartmentDAO类的实现的
直接了当的;它
直接使用了Java数据库联接调用来得到公寓的总数和符合用户请求的可用
公寓的列表。

  DWR配置和使用

  设置DWR的使用是简单的:将DWR的jar文件拷入Web应用的WEB-INF/lib
目录中,在web
.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</descri
ption>
        <servlet-class>uk.ltd.getahead.dwr.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>

========== * * * * * ==========
返回