首页 > 语言 > JavaScript > 正文

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

2024-05-06 16:25:15
字体:
来源:转载
供稿:网友

这篇文章主要介绍了javascript巧用eval函数组装表单输入项为json对象的方法,实例分析了JavaScript使用eval函数动态构造json对象的相关技巧,需要的朋友可以参考下

本文实例讲述了javascript巧用eval函数组装表单输入项为json对象的方法。分享给大家供大家参考,具体如下:

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

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

 

 
  1. var myObj = {};  
  2. myObj.x = document.getElementById("x").value;  
  3. myObj.y = document.getElementById("y").value; 
  4. //...  
  5. //然后ajax post或get提交 

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

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

 

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

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

 

 
  1. 运单号:<input type="text" name="AwbPre" value="112" style="width:40px"/>-<input type="text" name="AwbNo" value="12312311"/><br/> 
  2. 结算方式: 
  3. <select name="SettlementMode" style="width:100px"
  4. <option value="CASH" selected="selected">现金</option> 
  5. <option value="MONTH">月结</option> 
  6. </select> 
  7. <br/> 
  8. 不需要赋值的属性:<input type="input" name="NotMe" value="NotMe ..." isModel="false"/> 
  9. <script type="text/javascript"
  10. function setFormModel(modelName){ 
  11. eval(modelName + "={}"); 
  12. var inputArr = document.getElementsByTagName("INPUT"); 
  13. for(var i=0;i<inputArr.length;i++){ 
  14. var isModel = inputArr[i].getAttribute("isModel"); 
  15. var itemName = inputArr[i].name; 
  16. var itemValue = inputArr[i].value;  
  17. if(isModel!="false"){ 
  18. eval(modelName + "." + itemName + "='" + itemValue + "';"); 
  19. }  
  20. var selectArr = document.getElementsByTagName("SELECT"); 
  21. for(var i=0;i<selectArr.length;i++){ 
  22. var isModel = selectArr[i].getAttribute("isModel"); 
  23. var itemName = selectArr[i].name; 
  24. var itemValue = selectArr[i].value;  
  25. if(isModel!="false"){ 
  26. eval(modelName + "." + itemName + "='" + itemValue + "';"); 
  27. }  
  28. return modelName;  
  29. setFormModel("AwbModel"); 
  30. alert("单号:" + AwbModel.AwbPre + "-" + AwbModel.AwbNo + "/n结算方式:" + AwbModel.SettlementMode + "/n不该有的属性:" + AwbModel.NotMe); 
  31. </script> 

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

希望本文所述对大家JavaScript程序设计有所帮助。


注:相关教程知识阅读请移步到JavaScript/Ajax教程频道。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选