首先,配置dwr环境,网上很多资料都说得很详细,这里就不写了。

dwr封装form表单项,需要用到dwr定义的一个js方法:DWRUtil.getValues(yourform),这个方法可以返回一个指定form中的表单项的名称和值

的map对象。 
例如: 
<form name="myform"> 
<input type="text" name="userName" id="userName"/> 
<input type="password" name="passWord" name="passWord"/> 
</form>

那么DWRUtil.getValues("myform")将返回该form中的表单项的一个map对象。就不需要再写document.myform.username.value这样的语句了。 
我们可以通过dwr将这个自动封装好的表单对象返传给服务器端相关方法进行操作。如果需要的话,还可以在服务器端定义好对应的formbean来接收这个表单map。

关注流行国外网站

facebook:http://www.fb-on.com

facebook官网:http://www.facebookzh.com

facebook:http://www.cn-face-book.com

youtube:http://www.youtubezh.com

twitter:http://www.twitterzh.com

下面具体操作: 
1.配置好dwr运行环境。网上有很多例子,dwr所带的文档里也有说明。 
2.写一个formbean来接收表单,必须有对应的set、get方法:

  1. package dwr.test;
  2. public class FormBean {
  3. private String userName;
  4. private String passWord;
  5. public String getPassWord() {
  6. return passWord;
  7. }
  8. public void setPassWord(String passWord) {
  9. this.passWord = passWord;
  10. }
  11. public String getUserName() {
  12. return userName;
  13. }
  14. public void setUserName(String userName) {
  15. this.userName = userName;
  16. }
  17. }

3再写一个类来处理客户端发来的ajax请求:

  1. package dwr.test;
  2. import java.util.Map;
  3. import org.apache.commons.beanutils.BeanUtils;
  4. public class Service {
  5. public FormBean getFormBean(Map formMap){
  6. FormBean formBean = new FormBean();
  7. try{
  8. BeanUtils.populate(formBean, formMap);
  9. }catch(Exception e){
  10. e.printStackTrace();
  11. }
  12. System.out.println("==============客户端传来的信息==============");
  13. System.out.println("FormBean.username:"+formBean.getUserName());
  14. System.out.println("FormBean.password:"+formBean.getPassWord());
  15. System.out.println("=========================================");
  16. return formBean;
  17. }
  18. }

其中用到的BeanUtils.populate(formBean, formMap)方法可以将formMap内的对象复制给formBean对象的属性。 
BeanUtils类在struts库所带的包commons-beanutils.jar中。这样,来自客户端的表单项的值就被封装到服务器端的formBean中了,之后,操

作formBean就可以了。为了证实结果,用return formBean把封装后的表单内容返回到客户端。

4.在dwr.xml中注册相关的类及方法。 
<!DOCTYPE dwr PUBLIC 
    "-//GetAhead Limited//DTD Direct Web Remoting 1.0//EN" 
    "http://www.getahead.ltd.uk/dwr/dwr10.dtd"> 
<dwr> 
  <allow> 
<convert converter="bean" match="dwr.test.FormBean"/> 
    <create creator="new" javascript="Service"> 
    <param name="class" value="dwr.test.Service"/> 
  <include method="getFormBean"/> 
</create>   
  </allow> 
</dwr> 
注册FormBean是让客户端能够识别服务端返回的FormBean型数据

5.编写测试页面:test.htm 
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 
<html> 
  <head> 
   <title>test</title> 
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
    
  </head> 
   <script src='./dwr/interface/Service.js'></script> 
        <script src='./dwr/engine.js'></script> 
        <script src='./dwr/util.js'></script> 
       <script> 
  function formsubmit(){ 
         var formMap  = DWRUtil.getValues("testform"); 
         alert("客户端读取到的表单项:\nuserName:"+formMap["userName"]+"\npassWord:"+formMap["passWord"]); 
         Service.getFormBean(result,formMap); 
        } 
        function result(data) 
        { 
   alert("从服务端返回的数据:\nuserName:"+data.userName+"\npassWord:"+data.userName); 
        } 
    </script> 
  <body> 
          <form name="testform"> 
          userName:<input id="userName" name="userName" type="text"/><br/> 
          passWord:<input id="passWord" name="passWord" type="password" /><br/> 
          
          </form> 
         <input type="button" value="submit" onClick="formsubmit()"/> 
  </body> 
</html> 
注意:表单中的表单项的id的大小写必须和FormBean中定义的一致

用dwr封装表单项提交表单的更多相关文章

  1. 在jsp提交表单的参数封装到一个方法里

    建议去看一下孤傲苍狼写的Servlet+JSP+JavaBean开发模式(http://www.cnblogs.com/xdp-gacl/p/3902537.html), 最好把他JavaWeb学习总 ...

  2. OkHttp框架从入门到放弃,解析图片使用Picasso裁剪,二次封装OkHttpUtils,Post提交表单数据

    OkHttp框架从入门到放弃,解析图片使用Picasso裁剪,二次封装OkHttpUtils,Post提交表单数据 我们这片博文就来聊聊这个反响很不错的OkHttp了,标题是我恶搞的,本篇将着重详细的 ...

  3. 第一百五十九节,封装库--JavaScript,表单序列化结合ajax提交数据

    封装库--JavaScript,表单序列化结合ajax提交数据 封装库,表单序列化方法 /** xu_lie_biao_dan()方法,表单序列化方法,将自动获取指定表单里面的各项字段name值和va ...

  4. 第一百五十四节,封装库--JavaScript,表单验证--提交验证

    封装库--JavaScript,表单验证--提交验证 将表单的所有必填项,做一个判断函数,填写正确时返回布尔值 最后在提交时,判断每一项是否正确,全部正确才可以 提交 html <div id= ...

  5. 总结:JSP几种提交表单方法

    问题描述: 最近进了一家“老公司”工作,说他老不是说他成立的早,是因为他的编程框架太l.......low了.EJB的规范模式,使用是IBM经过Eclipse二次开发出来的RAD(Rational A ...

  6. SpringMVC中的异步提交表单

    1.前言 近期在做一个项目,前台框架用的是EasyUI+SpringMVC,因为对SpringMVC不太了解,所以刚開始接触的时候有点吃力,在此通过一个EasyUi中的DataGrid表格来总结一下. ...

  7. php 提交表单

    滴答…滴答…的雨,欢迎大家光临我的博客. 学习是快乐的,教育是枯燥的. 博客园   首页   博问   闪存     联系   订阅  管理 随笔-58  评论-2017  文章-5  trackba ...

  8. 利用ajaxSubmit()方法实现Form提交表单后回调

    1.      背景 最近在工作中,需要实现网页端图片上传到FTP服务器的功能.上传文件是用Form表单提交数据的方法向后台传输文件流,在此遇到了一个问题:后台在处理完图片上传功能后,需要向前台回传是 ...

  9. 第一百五十三节,封装库--JavaScript,表单验证--备注字数验证

    封装库--JavaScript,表单验证--备注字数验证 效果图 html <div id="reg"> <h2 class="tuo"> ...

随机推荐

  1. BZOJ4487 [Jsoi2015]染色问题

    BZOJ4487 [Jsoi2015]染色问题 题目描述 传送门 题目分析 发现三个限制,大力容斥推出式子是\(\sum_{i=0}^{N}\sum_{j=0}^{M}\sum_{k=0}^{C}(- ...

  2. 【bzoj1009】[HNOI2008]GT考试(矩阵快速幂优化dp+kmp)

    题目传送门:https://www.lydsy.com/JudgeOnline/problem.php?id=1009 这道题一看数据范围:$ n<=10^9 $,显然不是数学题就是矩乘快速幂优 ...

  3. select 下拉框 设置值

    function setSelectOption(objSelect, targetValue){ if(objSelect){ var options = objSelect.options; if ...

  4. MQ 个人小结

    在PCS项目: talking 发送队列1.1 创建@Beanpublic Queue orderTakingQueue() { return createQueue(orderTakingQueue ...

  5. Java_WebKit_ZC01

    1. 1.1. F:\ZC_chrome_download\java_svg\__Java_call_Qt\qtjambi-master\doc\src\snippets\application.xm ...

  6. EntityFramework之领域驱动设计实践

    EntityFramework之领域驱动设计实践 - 前言 EntityFramework之领域驱动设计实践 (一):从DataTable到EntityObject EntityFramework之领 ...

  7. DatePicker日期与时间控件

    DatePicker日期与时间控件 一.简介 二.方法 最日常的使用方法了 日期控件DatePicker 时间控件TimePicker 月份从0开始 三.代码实例 效果图: 代码: fry.Activ ...

  8. spring3: 对JDBC的支持 之 Spring提供的其它帮助 SimpleJdbcInsert/SimpleJdbcCall/SqlUpdate/JdbcTemplate 生成主键/批量处理

    7.4  Spring提供的其它帮助 7.4.1  SimpleJdbc方式 Spring JDBC抽象框架提供SimpleJdbcInsert和SimpleJdbcCall类,这两个类通过利用JDB ...

  9. 用WebClient在异步下载或上传时每次只进行一个任务 C#

    当在每次上传或者下载的时候,我只想进行一个任务的,我用的是WebClient类,但是我又不想用同步的方法UploadFile.DownloadFile,因为WebClient这个类的同步方法没有Upl ...

  10. jenkins 环境搭建与入门示例

    环境说明: 1.win7 2.tomcat 9.0.0.M17 3.jenkins 2.32.2.war jenkins 环境搭建 1.下载jenkins部署包 https://jenkins.io/ ...