接触过Angularjs的都知道,ng支持双向绑定,我们可以轻轻松松的通过ngModel将我们的值绑定到界面,当修改了值提交表单的时候不需要再重新通过ID去重新抓取输入框信息了。那对于我们开发前台网站,不用ng一类的MVVM框架,只引用了Jquery,那么在处理表单的时候该怎么做呢。

  一. 原始做法

  1. <div id="form">
  2. <select id='select1'>
  3. <option value="">--请选择--</option>
  4. <option value="1">--1--</option>
  5. <option value="2">--2--</option>
  6. <option value="3">--3--</option>
  7. </select>
  8. <input id='radio1' type="radio" />
  9. <input id='text1' type="text" />
  10. <textarea id='textArea1' ></textarea>
  11. </div>

   程序员A会说,So easy,通过Jquery id 去获取每个输入框的值就OK。多简单。

  1. function getEntity(){
  2. return {
  3. select1:$("#select1").val(),
  4. radio1:$("#radio1").prop('checked'),
  5. text1:$("text1").val(),
  6. textArea1:$("textArea1").val()
  7. }
  8. }

 二. 升级做法.

程序员B说, 这样不行哦,很多页面都有表单提交, 那不是每个地方都要用Jquery去获取值,如果以后新增了输入框,每次HTML修改了,还要修改对应的JS,多麻烦。于是爱偷懒的程序员B想到了一种方法,通过自定义标签来实现。

2.1  我们将表单包装到一个form的div下,每个输入的控件新增一个data-field属性. data-field里面写构建实体的属性名称,考虑到会出现嵌套的对象。所以data-field 里面属性名称通过 . 点来隔开,譬如  data-field='Person.Name' 后面就会构建出 { Person:{ Name:xxx }} .下面的是没有嵌套的对象的例子

  1. <div id="form">
  2. <select data-field='select1'>
  3. <option value="">--请选择--</option>
  4. <option value="1">--1--</option>
  5. <option value="2">--2--</option>
  6. <option value="3">--3--</option>
  7. </select>
  8. <input data-field='radio1' type="radio" />
  9. <input data-field='text1' type="text" />
  10. <textarea data-field='textArea1'></textarea>
  11. </div>

  2.2 提供一个getEntity方法。 读取外层的Form然后找到所有的data-field 属性去遍历. 因为输入框有checkbox和radio,input和select, 所以判断类型先取出值。然后调用getField方法构建实体。代码就不做详细解答了。应该都能看懂。只是想表达一下思路想法而已。

  1. function getEntity(form) {
  2. var result = {};
  3. $(form).find("[data-field]").each(function() {
  4. var field = $(this).attr("data-field");
  5. var val;
  6.  
  7. if ($(this).attr('type') == 'checkbox') {
  8. val = $(this).prop('checked');
  9. } else if ($(this).attr('type') == 'radio') {
  10. val = $(this).prop('checked');
  11. } else {
  12. val = $(this).val();
  13. }
  14.  
  15. // 获取单个属性的值,并扩展到result对象里面
  16. getField(field.split('.'), val, result);
  17. });
  18. return result;
  19. }
  1. function getField(fieldNames, value, result) {
  2. if (fieldNames.length > 1) {
  3. for (var i = 0; i < fieldNames.length - 1; i++) {
  4. if (result[fieldNames[i]] == undefined) {
  5. result[fieldNames[i]] = {}
  6. }
  7. result = result[fieldNames[i]];
  8. }
  9. result[fieldNames[fieldNames.length - 1]] = value;
  10. } else {
  11. result[fieldNames[0]] = value;
  12. }
  13. }

2.3 下面来看看上面输出的结果,哈哈值取到了。

2.4 下面我们来看看看嵌套的对象

  1. <div id="form">
  2. <select data-field='Person.Job'>
  3. <option value="">--职位--</option>
  4. <option value="java工程师">java工程师</option>
  5. <option value="net工程师">.net工程师</option>
  6. <option value="python工程师">python工程师</option>
  7. </select>
  8. <input data-field='Person.Desc' type="text" />
  9. </div>

2.5  提供了获取实体的方法,当然也要提供赋值的方法呀。下面来看看赋值的方法

  1. function setEntity(form, entity) {
  2.  
  3. $(form).find("[data-field]").each(function() {
  4.  
  5. var field = $(this).attr("data-field");
  6. fieldNames = field.split('.');
  7. var value = JSON.parse(JSON.stringify(entity));
  8. for (var index = 0; index < fieldNames.length; index++) {
  9. value = value[fieldNames[index]];
  10. if (!value) {
  11. break;
  12. }
  13. }
  14.  
  15. if ($(this).attr("type") === "checkbox" ||
  16. $(this).attr("type") === "radio") {
  17. $(this).attr('checked', Boolean(value));
  18. } else {
  19. if (value) {
  20. $(this).val(value);
  21. } else {
  22. $(this).val("");
  23. }
  24. }
  25. })
  26. }

呵呵,值附上去了.

三. 总结:

上面只是提供了解决方案, 虽然前台系统,不会考虑像后台backend 系统那样,用react,angularjs这种MVVM框架, 虽然只是用了一个Jquery而已。不过我们还是可以通过一些方法来简化项目代码的。

JS--轻松设置获取表单数据的更多相关文章

  1. Servlet的5种方式实现表单提交(注册小功能),后台获取表单数据

    用servlet实现一个注册的小功能 ,后台获取数据. 注册页面: 注册页面代码 : <!DOCTYPE html> <html> <head> <meta ...

  2. ASP.NET MVC 获取表单数据

    public class Person { public string Name{get;set;} public string Phone{get;set;} } view层 @model Mode ...

  3. 1.3(学习笔记)Servlet获取表单数据

    一.Servlet获取表单数据 表单提交数据经由Servlet处理,返回一个处理结果显示在页面上, 那么如何获取表单提交的参数进出相应的处理呢? 主要用到以下方法: String  getParame ...

  4. JSP简单练习-获取表单数据

    在JSP中,server端程序与client交互最经常使用的方法就是採用表单提交数据.表单提交的方法主要有两种,一种是get方法.还有一种是post方法.两者最大的差别:使用get方法提交的数据会显示 ...

  5. js 极简获取表单 元素 !

    let s =[]; $.each($('#formSearch input'),(m,n)=>{s.push(n)}); //示例获取表单所有 input 下滑线分割的 name 集合.set ...

  6. Servlet 响应 响应相关与重定向 请求 获取表单数据2种方法

    一.HttpServletResponse  (响应) 包括下面三个: 1.响应消息行  HTTP/1.1  200 OK 200是HTTP状态码, 代表请求已成功. (查httpservletres ...

  7. FromData获取表单数据

    一般想要不刷新页面提交数据时,可以使用ajax提交.如果数据量不大可以自己写json数据用ajax提交到后台服务,但是数据量多且需要动态添加数据时,自己写json格式数据就有点麻烦了,这时候就需要Fo ...

  8. 用Servlet获取表单数据

    用Servlet获取表单数据 在webroot下新建userRegist2.jsp 代码如下: <%@ page contentType="text/html;charset=gb23 ...

  9. php学习笔记-获取表单数据

    在网页上经常要填写用户名和密码,点击确认按纽之后,用户名和密码经过前端处理之后发送到了服务器上,那么服务器端怎么获取到这些用户提交的数据呢?就是通过超级全局变量 _POST和_GET 先拿_POST做 ...

随机推荐

  1. 【Win 10 应用开发】加载外部的 srt 字幕

    据说系统内置的多媒体功能支持 srt. ssa 等字幕,老周测试过几种格式的字幕均能加载. SRT 字幕是最简单的字幕结构,甚至你用记事本都能做出来,就是分为几行来写. 第一行是字幕的编号,应该是从1 ...

  2. ASP.NET MVC5+EF6+EasyUI 后台管理系统(51)-系统升级

    系统很久没有更新内容了,期待已久的更新在今天发布了,最近花了2个月的时间每天一点点,从原有系统 MVC4+EF5+UNITY2.X+Quartz 2.0+easyui 1.3.4无缝接入 MVC5+E ...

  3. Lisp和SICP

         大概不少programmer都看过<黑客与画家>,作者用了整整一章的篇幅讨论Lisp的强大.我自然就会手痒痒.      几个月前,几天内攻城略地搞定了Python,用的方法便是 ...

  4. XML技术之SAX解析器

    1.解析XML文件有三种解析方法:DOM SAX DOM4J. 2.首先SAX解析技术只能读取XML文档中的数据信息,不能对其文档中的数据进行添加,删除,修改操作:这就是SAX解析技术的一个缺陷. 3 ...

  5. ASP.NET 页面禁止被 iframe 框架引用

    两个站点: a.sample.com b.sample.com a.sample.com 站点中的一段示例 JS 代码: var iframe = document.createElement(&qu ...

  6. Hadoop入门学习笔记---part3

    2015年元旦,好好学习,天天向上.良好的开端是成功的一半,任何学习都不能中断,只有坚持才会出结果.继续学习Hadoop.冰冻三尺,非一日之寒! 经过Hadoop的伪分布集群环境的搭建,基本对Hado ...

  7. SELECT TOP 1 比不加TOP 1 慢的原因分析以及SELECT TOP 1语句执行计划预估原理

    本文出处:http://www.cnblogs.com/wy123/p/6082338.html 现实中遇到过到这么一种情况: 在某些特殊场景下:进行查询的时候,加了TOP 1比不加TOP 1要慢(而 ...

  8. Java正则速成秘籍(三)之见招拆招篇

    导读 正则表达式是什么?有什么用? 正则表达式(Regular Expression)是一种文本规则,可以用来校验.查找.替换与规则匹配的文本. 又爱又恨的正则 正则表达式是一个强大的文本匹配工具,但 ...

  9. Spring JdbcTemplate

    参考链接: https://my.oschina.net/u/437232/blog/279530 http://jinnianshilongnian.iteye.com/blog/1423897 J ...

  10. wpf 列表、菜单 收起与展开,通过Grid DoubleAnimation或者Expander实现

    菜单收缩有很多种方法具体如何实现还是看个人想法: 第一种通过后台控制收起与展开: 效果图: 代码 : <Grid> <Grid.ColumnDefinitions> <C ...