首先,配置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. SpringBoot Lombok

    简介 lombok是一个编译级别的插件,它可以在项目编译的时候生成一些代码.比如日常开发过程中需要生产大量的JavaBean文件,每个JavaBean都需要提供大量的get和set方法,如果字段较多且 ...

  2. get the request body of all quests before handle it

    https://stackoverflow.com/questions/23660340/need-to-log-asp-net-webapi-2-request-and-response-body- ...

  3. 通过wifi连接android设备的方法

    [转自]http://blog.csdn.net/kuanxu/article/details/7444874 最近由于要在另外一台android设备上调试代码,在本机PC上查看其log.两台机器离的 ...

  4. NumPy矩阵库

    NumPy - 矩阵库 NumPy 包包含一个 Matrix库numpy.matlib.此模块的函数返回矩阵而不是返回ndarray对象. matlib.empty() matlib.empty()函 ...

  5. Mongodb笔记(三)user && aggregate && mapReduce

    版本:mongodb3.4. User: mongodb使用验证登录:默认不开启,mongod中使用--auth开启:  mongod -port=3000 --auth  : 基本方法: db.cr ...

  6. selenium学习笔记(简单的元素定位)

    收拾一下心情开始新的一周工作 继续是selenium的学习.配置成功后 由于所有操作都是建立在页面元素基础上的.所以下来就是学习定位元素 首先是基础的定位.就使用博客园首页搜索框为例: 下面是代码: ...

  7. django-simple-captcha 使用 以及添加动态ajax刷新验证

    参考博客:http://blog.csdn.net/tanzuozhev/article/details/50458688?locationNum=2&fps=1 参考博客:http://bl ...

  8. hdu4348区间更新的主席树+标记永久化

    http://acm.hdu.edu.cn/showproblem.php?pid=4348 sb的标记永久化即可,刚开始add和sum没复制过来wa了两发...,操作和原来的都一样,出来单点变成区间 ...

  9. java JVM 随笔

    先说重点: 对象在堆区 方法在栈区 变量在方法区,常量池在方法区 为什么要了解Java 虚拟机 ? 这个问题一直困惑了我很长一段时间,其实在我们开发的过程中,即使我们不了解JVM也能正常的开发,但是当 ...

  10. 【poj2553】The Bottom of a Graph(强连通分量缩点)

    题目链接:http://poj.org/problem?id=2553 [题意] 给n个点m条边构成一幅图,求出所有的sink点并按顺序输出.sink点是指该点能到达的点反过来又能回到该点. [思路] ...