- 浏览: 2869671 次
- 性别:
- 来自: 武汉
文章分类
- 全部博客 (1173)
- 名言警句 (5)
- 心情随笔 (50)
- 数据库 (57)
- Java基础 (241)
- J2EE框架 (91)
- 数据结构 (12)
- 程序设计 (21)
- WEB技术 (128)
- 网络日志 (12)
- IT资讯 (247)
- linux (64)
- solaris (2)
- 其它 (143)
- WebService (4)
- 日语学习 (2)
- 机器人 (5)
- Android (5)
- cgywin (3)
- Game (1)
- DWR (1)
- spring (8)
- canvas (1)
- Guava (3)
- Modbus (5)
- 测试 (6)
- mongodb (9)
- Quartz (2)
- Cron (1)
- windows (2)
- 持续集成 (1)
- bootstrap (3)
- 结对编程 (1)
- nodejs (1)
- Netty (1)
- 安全 (3)
- webstorm (2)
- sparkline (1)
- Job (1)
- git (3)
- Maven (3)
- knockout (5)
- jquery (1)
- bower (1)
- docker (1)
- confluence (4)
- wiki (1)
- GoogleMap (1)
- jekyll (10)
- ruby (2)
- npm (3)
- browserify (1)
- gulp (3)
- openwrt (1)
- discuz (3)
- 输入法 (1)
- JPA (1)
- eclipse (2)
- IntelliJ (1)
- css (1)
- 虚拟机 (1)
- 操作系统 (1)
- azkaban (2)
- scrum (1)
最新评论
-
pangxiea_:
你好, 想请问一下 Linux下 这么使用rxtxcomm 在 ...
使用Java进行串口通信 -
abababudei:
请教一下,这个您是怎么解决的:/dev/ttyS2enteri ...
Java应用程序的MODBUS通讯 -
xuniverse:
hannibal005 写道楼主,我问下 request.se ...
用javascript与java进行RSA加密与解密 -
atxkm:
找了一下午,终于找到了
gulp 拷贝文件时如何移除文件目录结构 -
kalogen:
gtczr 写道非常感谢,经过我自己的修改,已经完美实现。发出 ...
用javascript与java进行RSA加密与解密
首先配置好dwr框架所需的文件。
dwr的配置过程:
在/WEB-INF/lib中加入dwr.jar文件
在web.xml中加载dwr对应的servlet
在/WEB-INF/中加入dwr.xml文件
在jsp加入如下内容
〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉
有几点要注意:
dwr.xml是声明的类名要与页面中声明的类名一致,如
<script type="text/javascript" src="dwr/interface/QueryManagerDAO.js"></script>
与dwr.xml中
<create javascript="QueryManagerDAO" creator="new">
<param name="class" value="com.syscanhc.tjy.data.dao.impl.QueryManagerDAO"></param>
</create>
另外,QueryManagerDAO.getTableColumn()方法中如用到javaBean或者其它对象要在<convert</convert>中声明。如:
<convert match="map" converter="java.util.Map"></convert>
注意
items的类型为java.util.Map
["====待选择查询字段===="]为Array
DWRUtil.addOptions('startSelects',items,true)表示将显示的key与value互换显示
show为一回调函数,返回的结果在function show(items){}的items中
dwr的配置过程:
在/WEB-INF/lib中加入dwr.jar文件
在web.xml中加载dwr对应的servlet
<servlet> <servlet-name>dwr</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</servlet-name> <url-pattern>/dwr/*</url-pattern> </servlet-mapping>
在/WEB-INF/中加入dwr.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="spring" javascript="bmgl"> <param name="beanName" value="BmglService"/> <include method="checkBmId" /> </create> <create creator="spring" javascript="JcyqlbService" > <param name="beanName" value="JcyqlbService"/> <include method="findJcyqlb" /> </create> <create creator="spring" javascript="reportManageService" > <param name="beanName" value="reportManageService"/> <include method="isHaveBackReport" /> </create> <create creator="spring" javascript="YwslService" > <param name="beanName" value="YwslService"/> <include method="getBmList" /> <include method="getDeviceList" /> <include method="findDeviceBySydw" /> <include method="findGcjyDeviceBySydw" /> <include method="getDeviceCheckState" /> <include method="validateSbJynr" /> <include method="getSbYxzt" /> <include method="findBargainByEmployId" /> <include method="findBargainUrl" /> <include method="getCooperateCorporation" /> <include method="findAllGgSbjcByGzdid" /> <include method="findAllGgSbjcByTzsbbhs" /> <include method="findAllHtByid" /> </create> <create creator="spring" javascript="GjxwhService" > <param name="beanName" value="GjxwhService"/> <include method="findRy" /> <include method="getAllYqList" /> </create> <create creator="spring" javascript="xtSbzlService" > <param name="beanName" value="xtSbzlService"/> <include method="findSbzlList" /> <include method="findJyxzList" /> <include method="findJynrList" /> <include method="findGcjyJynrList" /> <include method="findSbpzList" /> <include method="findStaySbpzList" /> </create> <convert converter="bean" match="com.syscanhc.tjy.data.bo.GgGjx"> <param name="include" value="id, gjxmc" /> </convert> <convert converter="bean" match="com.syscanhc.tjy.data.bo.TbmBmk"> <param name="include" value="dm,sm" /> </convert> <create javascript="QueryManagerDAO" creator="new"> <param name="class" value="com.syscanhc.tjy.data.dao.impl.QueryManagerDAO"></param> </create> <convert match="map" converter="java.util.Map"></convert> </allow> </dwr>
在jsp加入如下内容
<%@ taglib uri="/WEB-INF/struts-bean.tld" prefix="bean"%> <%@ taglib uri="/WEB-INF/struts-html.tld" prefix="html"%> <%@ taglib uri="/WEB-INF/struts-logic.tld" prefix="logic"%> <%@ page contentType="text/html; charset=GBK"%> <html> <head> <link href="css/style.css" rel="stylesheet" type="text/css"> <script language="JavaScript" src="js/system.js"></script> <script type="text/javascript" src='dwr/engine.js'></script> <script type="text/javascript" src='dwr/util.js'></script> <script type="text/javascript" src="dwr/interface/QueryManagerDAO.js"></script> <script language="javascript" type="text/javascript"> function show(items) { DWRUtil.removeAllOptions('startSelects'); DWRUtil.addOptions('startSelects',["====待选择查询字段===="]); DWRUtil.addOptions('startSelects',items); } function getItems() { QueryManagerDAO.getTableColumn($('tableName').value,show); } </script> <title>动态查询主页面</title> </head> <body > <table border="0" cellspacing="0" cellpadding="0" width="50%" id="table1"> <html:form action="/query_Gzd?method=setOptions" method="post"> <tr><td> <html:select property="tableName" styleClass="inputtext" onchange="getItems();"> <html:options collection="tableItems" labelProperty="key" property="value"/> </html:select></td></tr> <tr> <td> <table width="100%" border="0" cellspacing="0" class="DefaultTable"> <tr class="sysdisplay"> <td align="right"> </td> <td> <html:select property="startSelects" styleClass="inputtext" size="10" multiple="true"> <html:option value="">====待选择查询字段====</html:option> <html:options collection="gzdItems" labelProperty="value" property="key"/> </html:select></td> <td align="center"><input type="button" value="添加>>" class="btn2" onClick="addItem()"> <p> <p><input type="button" value="<<移除" class="btn2" onClick="deleteItem()"> </td> <td><html:select property="endSelects" style="weight:80px" styleClass="inputtext" size="10" multiple="true"> <html:option value="">====已选择查询字段====</html:option> </html:select></td> </tr> <tr class="sysdisplay"> <td colspan="4" align="center"><input type="button" value="确 定" class="btn2" onclick="submitOptions();"> <input type="button" name="Submit32" onClick="window.close();" class="btn2" value="关 闭"></td> </tr> </table> </td> </tr> </html:form> </table> <script language="javascript"> <!-- function submitOptions() { var result=""; var selto = document.getElementById("endSelects"); for(var i=selto.options.length-1;i>=1;i--) { result=result+selto.options[i].text+","; } if(result.length>0){ result = result.substr(0,result.length-1); } gzdSearchForm.resultList.value=result; var ss= window.confirm("是否保存查询条件?"); if(ss) { var searchName=window.showModalDialog("saveTempl.html",window,"dialogHeight:100px,center:yes,resizable:no,status:no"); gzdSearchForm.action=gzdSearchForm.action+"&searchName="+searchName; } gzdSearchForm.submit(); } function addItem() { var selfrom=document.getElementById("startSelects"); var selto=document.getElementById("endSelects"); for(var i=selfrom.options.length-1;i>=1;i--) { if(selfrom.options[i].selected) { var index = selto.length; selto.options[index]=new Option(selfrom.options[i].text,selfrom.options[i].value); selfrom.remove(i); } } } function deleteItem() { var selto=document.getElementById("startSelects"); var selfrom=document.getElementById("endSelects"); for(var i=selfrom.options.length-1;i>=1;i--) { if(selfrom.options[i].selected) { selto.options[selto.length]=new Option(selfrom[i].text,selfrom[i].value); selfrom.remove(i); } } } //--> </script> </body> </html>
〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉〉
有几点要注意:
dwr.xml是声明的类名要与页面中声明的类名一致,如
<script type="text/javascript" src="dwr/interface/QueryManagerDAO.js"></script>
与dwr.xml中
<create javascript="QueryManagerDAO" creator="new">
<param name="class" value="com.syscanhc.tjy.data.dao.impl.QueryManagerDAO"></param>
</create>
另外,QueryManagerDAO.getTableColumn()方法中如用到javaBean或者其它对象要在<convert</convert>中声明。如:
<convert match="map" converter="java.util.Map"></convert>
注意
DWRUtil.removeAllOptions('startSelects'); DWRUtil.addOptions('startSelects',["====待选择查询字段===="]); DWRUtil.addOptions('startSelects',items);的用法
items的类型为java.util.Map
["====待选择查询字段===="]为Array
DWRUtil.addOptions('startSelects',items,true)表示将显示的key与value互换显示
show为一回调函数,返回的结果在function show(items){}的items中
- DWR中文文档v0.9.rar (1.1 MB)
- 描述: DWR中文文档
- 下载次数: 294
发表评论
-
spring mvc @controller unit test
2013-11-20 14:14 38861. spring mvc controller imple ... -
Tomcat 生产服务器性能优化
2013-07-23 06:45 1007试想以下这个情景:你已经开发好了一个程序,这个程序的排版很不 ... -
Loading Multiple Spring Application Contexts with their own ClassLoader
2013-07-11 20:45 1072package de.incompleteco.spring ... -
ActiveMQ JMS的测试
2011-04-06 18:15 3918有二种方式可以测试。 1. 透过testng, 在测试类中完 ... -
Maven系列2--pom.xml 配置详解
2011-01-06 18:00 3176<project xmlns="http ... -
fisheye2.3.6 安装笔记
2010-09-16 20:25 2234一. 准备工作 1. 下载fisheye ... -
服务器端编程的十大性能问题
2010-09-15 12:01 1233今年5 月底,瑞士计算 ... -
JMX in spring 配置
2010-09-07 12:00 3050JConsole中的连接:简单的localhost:1099 ... -
Ehcache 2.0:后写式缓存和JTA支持
2010-05-22 11:13 1854开源缓存框架Ehcache 最 ... -
Twitter系统运维经验
2010-04-12 22:24 1551最近看到的另外一个 ... -
采用OSGi框架开发项目的十个问题
2010-03-21 18:08 1462近期,InfoQ针对Java模块 ... -
IBM和Eclipse加大对OSGi的支持
2010-03-21 18:05 1272为Java提供模块性的OSGi,正在受到IBM和Eclipse ... -
Castor功能与应用参考
2010-03-12 12:48 36271. 项目简介Castor是一个开源的Java项目 ... -
hibernate之 DetachedCriteria实现多表查询
2009-07-25 17:13 13092DetachedCriteria detachedCriter ... -
spring AOP 理论知识点总结
2009-07-24 17:47 21741.1 AOP 的概念 ... -
web.xml 中的listener、 filter、servlet 加载顺序及其详解
2009-07-02 16:14 4122在项目中总会遇到一些 ... -
maven笔记
2009-06-22 22:14 1529mvn package : 项目打包 mvn help:ef ... -
利用maven构建多模块项目
2009-06-17 14:28 53611. 先单独构建各模块为一个独立的项目。 jar项目: m ... -
Maven基础
2009-06-17 12:58 1859下载Maven安装文件。 定义环境变量M2_HOME到pat ... -
安装M2eclipse步骤
2009-06-15 14:45 38221.下载下列所需文件 eclipse3.4.2 ...
相关推荐
总结来说,利用Ajax和DWR框架实现的二级联动下拉列表,使得用户可以在不刷新页面的情况下完成多级选择,提升了用户体验。同时,DWR的使用简化了前后端交互的复杂性,使得开发更为高效。通过阅读和理解提供的源代码,...
Java+dwr 框架实现聊天室 Java+dwr框架实现聊天室是使用Java语言和dwr框架实现的服务器推技术,实现了实时通信的聊天室功能。下面将详细介绍该技术的实现过程和相关知识点。 一、dwr 框架简介 dwr(Direct Web ...
在“dwr.rar_dwr_dwr ajax_dwr 实现 联动 标签”这个项目中,我们将探讨如何利用DWR和AJAX技术来创建一个动态的、具有联动效果的标签系统。 1. **DWR基础**: DWR的核心组件包括一个服务器端的Servlet(DWR Engine...
"dwr框架+struts+Hibernate实现下拉菜单二级联动"是一个典型的Web应用程序开发技术组合,它旨在创建一个动态且响应式的交互式UI,特别是在处理关联数据时。下面我们将深入探讨这个主题。 首先,DWR(Direct Web ...
【标题】"DWR整合SSH框架实现类百度搜索实例(Oracle)"是一个综合性的IT实践项目,旨在演示如何将Direct Web Remoting (DWR) 框架与Spring、Struts和Hibernate(通常被称为SSH框架)集成,以创建一个类似于百度搜索...
标题 "DWR实现省市县三级联动小例子" 暗示了这个压缩包可能包含一个使用Direct Web Remoting (DWR) 技术构建的示例项目,该示例展示了如何实现在网页上进行省、市、县三级联动选择的功能。这种功能在很多中国的网站...
DWR (Direct Web Remoting) 是一个开源的Java框架,用于在Web应用程序中实现JavaScript与服务器端Java代码的交互。DWR使得动态的Web页面能够像调用本地方法一样调用服务器上的Java方法,极大地提高了Web应用的用户...
1. **自动完成/下拉列表**:用户输入时,DWR可以从服务器获取匹配的建议列表,动态填充到输入框下方。 2. **表格数据动态加载**:用户滚动表格时,DWR加载额外的数据行,实现无限滚动效果。 3. **表单验证**:在...
DWR(Direct Web Remoting)是一种JavaScript和Java之间的远程调用技术,它允许Web应用在不刷新整个页面的情况下与服务器进行交互,从而实现动态更新和实时反馈的效果。在DWR中,JavaScript对象可以直接调用后台的...
dwr 框架dwr 框架dwr 框架dwr 框架dwr 框架dwr 框架
在介绍的省市县三级联动的例子中,通过DWR与AJAX的结合使用,可以实现用户在选择一个省级别之后,页面能够动态地加载并显示该省份下属的所有市级选项。同样地,再选择一个市级之后,页面能够加载并显示该市下属的...
总结,"dwr 实现2级联动"是利用DWR框架来创建一个前端与后端交互的示例,通过动态更新页面元素,达到两个选择框之间的联动效果。在实际开发中,DWR提供了一种便捷的方式来进行异步通信,提高了Web应用的交互体验。
在本案例中,DWR被用于实现一个省市县三级联动的选择器,即当用户选择一个省份时,相应的城市列表会自动更新;当用户选择了一个城市后,相关的县区列表也会随之更新。 #### 二、关键技术栈 - **Spring 2.0.5**:...
每当用户在搜索框中键入字符,DWR会自动发送异步请求,查询数据库中的相关数据,并实时更新到搜索结果列表。这样,用户可以看到随着输入的每个字符,搜索结果动态变化,提高了搜索效率和用户体验。 综上所述,这个...
AJAX技术的核心在于能够在不重新加载整个网页的情况下,通过JavaScript与服务器进行数据交换,从而实现网页的部分更新。这种技术能够提供更加流畅的用户体验,减少服务器的负担,并提高应用程序的响应速度。AJAX技术...
在IT行业中,SSH(Spring、Struts、Hibernate)是一个经典的Java Web开发框架组合,而DWR(Direct Web Remoting)则是一种JavaScript与服务器端交互的技术,常用于实现AJAX功能。本篇主要讨论如何利用SSH框架和DWR来...