JS--轻松设置获取表单数据
接触过Angularjs的都知道,ng支持双向绑定,我们可以轻轻松松的通过ngModel将我们的值绑定到界面,当修改了值提交表单的时候不需要再重新通过ID去重新抓取输入框信息了。那对于我们开发前台网站,不用ng一类的MVVM框架,只引用了Jquery,那么在处理表单的时候该怎么做呢。
一. 原始做法
- <div id="form">
- <select id='select1'>
- <option value="">--请选择--</option>
- <option value="1">--1--</option>
- <option value="2">--2--</option>
- <option value="3">--3--</option>
- </select>
- <input id='radio1' type="radio" />
- <input id='text1' type="text" />
- <textarea id='textArea1' ></textarea>
- </div>
程序员A会说,So easy,通过Jquery id 去获取每个输入框的值就OK。多简单。
- function getEntity(){
- return {
- select1:$("#select1").val(),
- radio1:$("#radio1").prop('checked'),
- text1:$("text1").val(),
- textArea1:$("textArea1").val()
- }
- }
二. 升级做法.
程序员B说, 这样不行哦,很多页面都有表单提交, 那不是每个地方都要用Jquery去获取值,如果以后新增了输入框,每次HTML修改了,还要修改对应的JS,多麻烦。于是爱偷懒的程序员B想到了一种方法,通过自定义标签来实现。
2.1 我们将表单包装到一个form的div下,每个输入的控件新增一个data-field属性. data-field里面写构建实体的属性名称,考虑到会出现嵌套的对象。所以data-field 里面属性名称通过 . 点来隔开,譬如 data-field='Person.Name' 后面就会构建出 { Person:{ Name:xxx }} .下面的是没有嵌套的对象的例子
- <div id="form">
- <select data-field='select1'>
- <option value="">--请选择--</option>
- <option value="1">--1--</option>
- <option value="2">--2--</option>
- <option value="3">--3--</option>
- </select>
- <input data-field='radio1' type="radio" />
- <input data-field='text1' type="text" />
- <textarea data-field='textArea1'></textarea>
- </div>
2.2 提供一个getEntity方法。 读取外层的Form然后找到所有的data-field 属性去遍历. 因为输入框有checkbox和radio,input和select, 所以判断类型先取出值。然后调用getField方法构建实体。代码就不做详细解答了。应该都能看懂。只是想表达一下思路想法而已。
- function getEntity(form) {
- var result = {};
- $(form).find("[data-field]").each(function() {
- var field = $(this).attr("data-field");
- var val;
- if ($(this).attr('type') == 'checkbox') {
- val = $(this).prop('checked');
- } else if ($(this).attr('type') == 'radio') {
- val = $(this).prop('checked');
- } else {
- val = $(this).val();
- }
- // 获取单个属性的值,并扩展到result对象里面
- getField(field.split('.'), val, result);
- });
- return result;
- }
- function getField(fieldNames, value, result) {
- if (fieldNames.length > 1) {
- for (var i = 0; i < fieldNames.length - 1; i++) {
- if (result[fieldNames[i]] == undefined) {
- result[fieldNames[i]] = {}
- }
- result = result[fieldNames[i]];
- }
- result[fieldNames[fieldNames.length - 1]] = value;
- } else {
- result[fieldNames[0]] = value;
- }
- }
2.3 下面来看看上面输出的结果,哈哈值取到了。
2.4 下面我们来看看看嵌套的对象
- <div id="form">
- <select data-field='Person.Job'>
- <option value="">--职位--</option>
- <option value="java工程师">java工程师</option>
- <option value="net工程师">.net工程师</option>
- <option value="python工程师">python工程师</option>
- </select>
- <input data-field='Person.Desc' type="text" />
- </div>
2.5 提供了获取实体的方法,当然也要提供赋值的方法呀。下面来看看赋值的方法
- function setEntity(form, entity) {
- $(form).find("[data-field]").each(function() {
- var field = $(this).attr("data-field");
- fieldNames = field.split('.');
- var value = JSON.parse(JSON.stringify(entity));
- for (var index = 0; index < fieldNames.length; index++) {
- value = value[fieldNames[index]];
- if (!value) {
- break;
- }
- }
- if ($(this).attr("type") === "checkbox" ||
- $(this).attr("type") === "radio") {
- $(this).attr('checked', Boolean(value));
- } else {
- if (value) {
- $(this).val(value);
- } else {
- $(this).val("");
- }
- }
- })
- }
呵呵,值附上去了.
三. 总结:
上面只是提供了解决方案, 虽然前台系统,不会考虑像后台backend 系统那样,用react,angularjs这种MVVM框架, 虽然只是用了一个Jquery而已。不过我们还是可以通过一些方法来简化项目代码的。
JS--轻松设置获取表单数据的更多相关文章
- Servlet的5种方式实现表单提交(注册小功能),后台获取表单数据
用servlet实现一个注册的小功能 ,后台获取数据. 注册页面: 注册页面代码 : <!DOCTYPE html> <html> <head> <meta ...
- ASP.NET MVC 获取表单数据
public class Person { public string Name{get;set;} public string Phone{get;set;} } view层 @model Mode ...
- 1.3(学习笔记)Servlet获取表单数据
一.Servlet获取表单数据 表单提交数据经由Servlet处理,返回一个处理结果显示在页面上, 那么如何获取表单提交的参数进出相应的处理呢? 主要用到以下方法: String getParame ...
- JSP简单练习-获取表单数据
在JSP中,server端程序与client交互最经常使用的方法就是採用表单提交数据.表单提交的方法主要有两种,一种是get方法.还有一种是post方法.两者最大的差别:使用get方法提交的数据会显示 ...
- js 极简获取表单 元素 !
let s =[]; $.each($('#formSearch input'),(m,n)=>{s.push(n)}); //示例获取表单所有 input 下滑线分割的 name 集合.set ...
- Servlet 响应 响应相关与重定向 请求 获取表单数据2种方法
一.HttpServletResponse (响应) 包括下面三个: 1.响应消息行 HTTP/1.1 200 OK 200是HTTP状态码, 代表请求已成功. (查httpservletres ...
- FromData获取表单数据
一般想要不刷新页面提交数据时,可以使用ajax提交.如果数据量不大可以自己写json数据用ajax提交到后台服务,但是数据量多且需要动态添加数据时,自己写json格式数据就有点麻烦了,这时候就需要Fo ...
- 用Servlet获取表单数据
用Servlet获取表单数据 在webroot下新建userRegist2.jsp 代码如下: <%@ page contentType="text/html;charset=gb23 ...
- php学习笔记-获取表单数据
在网页上经常要填写用户名和密码,点击确认按纽之后,用户名和密码经过前端处理之后发送到了服务器上,那么服务器端怎么获取到这些用户提交的数据呢?就是通过超级全局变量 _POST和_GET 先拿_POST做 ...
随机推荐
- 【Win 10 应用开发】加载外部的 srt 字幕
据说系统内置的多媒体功能支持 srt. ssa 等字幕,老周测试过几种格式的字幕均能加载. SRT 字幕是最简单的字幕结构,甚至你用记事本都能做出来,就是分为几行来写. 第一行是字幕的编号,应该是从1 ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(51)-系统升级
系统很久没有更新内容了,期待已久的更新在今天发布了,最近花了2个月的时间每天一点点,从原有系统 MVC4+EF5+UNITY2.X+Quartz 2.0+easyui 1.3.4无缝接入 MVC5+E ...
- Lisp和SICP
大概不少programmer都看过<黑客与画家>,作者用了整整一章的篇幅讨论Lisp的强大.我自然就会手痒痒. 几个月前,几天内攻城略地搞定了Python,用的方法便是 ...
- XML技术之SAX解析器
1.解析XML文件有三种解析方法:DOM SAX DOM4J. 2.首先SAX解析技术只能读取XML文档中的数据信息,不能对其文档中的数据进行添加,删除,修改操作:这就是SAX解析技术的一个缺陷. 3 ...
- ASP.NET 页面禁止被 iframe 框架引用
两个站点: a.sample.com b.sample.com a.sample.com 站点中的一段示例 JS 代码: var iframe = document.createElement(&qu ...
- Hadoop入门学习笔记---part3
2015年元旦,好好学习,天天向上.良好的开端是成功的一半,任何学习都不能中断,只有坚持才会出结果.继续学习Hadoop.冰冻三尺,非一日之寒! 经过Hadoop的伪分布集群环境的搭建,基本对Hado ...
- SELECT TOP 1 比不加TOP 1 慢的原因分析以及SELECT TOP 1语句执行计划预估原理
本文出处:http://www.cnblogs.com/wy123/p/6082338.html 现实中遇到过到这么一种情况: 在某些特殊场景下:进行查询的时候,加了TOP 1比不加TOP 1要慢(而 ...
- Java正则速成秘籍(三)之见招拆招篇
导读 正则表达式是什么?有什么用? 正则表达式(Regular Expression)是一种文本规则,可以用来校验.查找.替换与规则匹配的文本. 又爱又恨的正则 正则表达式是一个强大的文本匹配工具,但 ...
- Spring JdbcTemplate
参考链接: https://my.oschina.net/u/437232/blog/279530 http://jinnianshilongnian.iteye.com/blog/1423897 J ...
- wpf 列表、菜单 收起与展开,通过Grid DoubleAnimation或者Expander实现
菜单收缩有很多种方法具体如何实现还是看个人想法: 第一种通过后台控制收起与展开: 效果图: 代码 : <Grid> <Grid.ColumnDefinitions> <C ...