javascript:巧用eval函数组装表单输入项为json对象

在ajax方式做web开发时,经常会遇到会保存前,收集表单输入项,组成json对象,然后把对象直接post到服务端的场景

常规做法是在js里写类似如下的代码:

var myObj = {};  

myObj.x = document.getElementById("x").value;  

myObj.y = document.getElementById("y").value; 
 
//...  

//然后ajax post或get提交

表单元素不多的时候,这样还好,但是如果一个表单有好几十项甚至更多输入项的时候,写这种代码就太费劲了。

好在javascript中有一个邪恶的eval函数,可以帮我们完成一些类似c#反射的工作,比如下面这样:

 eval('A={}');
 if (A.b==undefined)
 {
  A.b = {};
 }
 eval('A.b.c = 1');
 alert(A.b.c);

 这样,我们就动态创建了一个复合对象A,明白其中原理后,可以对表单做些改进:

运单号:<input type="text" name="AwbPre" value="112" style="width:40px"/>-<input type="text" name="AwbNo"  value="12312311"/><br/>
结算方式:
<select name="SettlementMode" style="width:100px">
	<option value="CASH" selected="selected">现金</option>
	<option value="MONTH">月结</option>
</select>
<br/>
不需要赋值的属性:<input type="input" name="NotMe" value="NotMe ..." isModel="false"/>


<script type="text/javascript">


	function setFormModel(modelName){
		eval(modelName + "={}");
		var inputArr = document.getElementsByTagName("INPUT");
		for(var i=0;i<inputArr.length;i++){
			var isModel = inputArr[i].getAttribute("isModel");
			var itemName = inputArr[i].name;
			var itemValue = inputArr[i].value;			
			if(isModel!="false"){
				eval(modelName + "." + itemName + "='" + itemValue + "';");
			}			
		}

		var selectArr = document.getElementsByTagName("SELECT");
		for(var i=0;i<selectArr.length;i++){
			var isModel = selectArr[i].getAttribute("isModel");
			var itemName = selectArr[i].name;
			var itemValue = selectArr[i].value;			
			if(isModel!="false"){
				eval(modelName + "." + itemName + "='" + itemValue + "';");
			}			
		}
		return modelName;		
	}

	setFormModel("AwbModel");

	alert("单号:" + AwbModel.AwbPre + "-" + AwbModel.AwbNo + "\n结算方式:" + AwbModel.SettlementMode + "\n不该有的属性:" + AwbModel.NotMe);

</script>

 这样,只要form元素的name属性正确设置,需要收集表单对象时,调用一下setFormModel函数,就能快速得到一个json对象(当然这只是示例,仅处理了一级属性的情况,如果有多级属性,大家自己去扩展吧,无非就是字符串上做些文章)

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏编程微刊

promis:异步编程

15710
来自专栏java架构师

C# 多线程

 Thread类的使用: 初始化: Thread th1 = new Thread(function1); Thread th2 = new Thread(ne...

33660
来自专栏Theo Tsao

Vim的基本使用(一)

本文包含Vim的基本使用有: 移动光标、屏幕滚动、模式查找、位置标记、删除文本、撤销与重做、插入文本、复制与移动、修改文本、写入与退出。

10930
来自专栏烂笔头

Python标准库笔记(6) — struct模块

目录[-] 该模块作用是完成Python数值和C语言结构体的Python字符串形式间的转换。这可以用于处理存储在文件中或从网络连接中存储的二进制数据,以及其...

49450
来自专栏盛国存的专栏

A Bite of GoLang(中)

上述的 v 就称为局部变量, sum 称为自由变量,`func(v int) int {

65770
来自专栏Java技术分享

XML基本语法

 导入一个XML文件可分为如下几部分内容:文档声明 、元素、属性、注释 、CDATA区 ,特殊字符 、处理指令

262100
来自专栏Modeng的专栏

Vue中如何使用方法、计算属性或观察者

熟悉 Vue 的都知道 方法methods、计算属性computed、观察者watcher 在 Vue 中有着非常重要的作用,有些时候我们实现一个功能的时候可以...

14720
来自专栏雪地二货笔记库

vue学习笔记11-自定义指令

除了默认设置的核心指令( v-model 和 v-show ), Vue 也允许注册自定义指令。 注册指令的关键字是directive, 同样也有局部和全局之分...

9910
来自专栏Pythonista

golang之panic,recover,defer

recover内建函数用于“拦截”运行时恐慌,可以使当前的程序从恐慌状态中恢复并重新获得流程控制权。

17210
来自专栏python成长之路

文件的指针位置

21840

扫码关注云+社区

领取腾讯云代金券