首先,配置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. JAVA基础补漏--反射

    获得CLASS的三种方式: 1.Class.forname("全类名"):将字节码文件加载进内存,返回Class对象. 多用于配置文件,将类名放到配置文件中,读取配置文件,加载类 ...

  2. Codeforces Round #364 (Div. 2) C. They Are Everywhere 尺取法

    C. They Are Everywhere time limit per test 2 seconds memory limit per test 256 megabytes input stand ...

  3. ssm框架搭建流程及原理分析

    这几天自己想搭建个ssm框架玩一下,有些东西长时间不玩都给忘了,所以自己把整个流程整理了一下,只要跟着步骤,就能顺利完成ssm框架的搭建. 一.搭建步骤: 1.整理jar包     2.对于一个web ...

  4. angular2.x 多选框事件

    angular2.x - 4.x  的多选框事件 ng2 -- ng4 反正都是用es6 都统称为2.x吧. 下面贴代码 html界面 <div class="row"> ...

  5. 接口测试工具---postman下载地址

    接口测试工具---postman下载地址: https://app.getpostman.com/app/download/win64?_ga=2.3555895.622696496.15081214 ...

  6. 51nod-1385-贪心-构造

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1385 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 ...

  7. 前端读取Excel报表文件 js-xlsx

    1.http://www.cnblogs.com/imwtr/p/6001480.html (前端读取Excel报表文件) 2.https://github.com/SheetJS/js-xlsx

  8. IOS-视频

    一.简介 iOS提供了MPMoviePlayerController.MPMoviePlayerViewController两个类,可以用来轻松播放视频和网络流媒体\网络音频 提示:网络音频同样使用此 ...

  9. MySQL 5.6 二进制包安装配置多实例方法

    MySQL支持一台机器上启动多个实例,如果你的机器性能很好的话,启动多个实例将最大化利用你的服务器硬件资源. MySQL多实例一般有两种配置方法: 1.官方推荐的mysqld_multi方式,多个实例 ...

  10. LeetCode OJ:Combination Sum II (组合之和 II)

    Given a collection of candidate numbers (C) and a target number (T), find all unique combinations in ...