表单序列化

 

jQuery - 基于serializeArray的serializeObject


jQuery有方法$.fn.serialize,可将表单序列化成字符串;有方法$.fn.serializeArray,可将表单序列化成数组。
如果需要其序列化为JSON对象,那么可以基于serializeArray编写方法serializeObject轻松实现:

[javascript]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. //work with jQuery 1.x  
  2. jQuery.prototype.serializeObject=function(){  
  3.     var obj=new Object();  
  4.     $.each(this.serializeArray(),function(index,param){  
  5.         if(!(param.name in obj)){  
  6.             obj[param.name]=param.value;  
  7.         }  
  8.     });  
  9.     return obj;  
  10. };  


注:当表单中参数出现同名时,serializeObject会取第一个,而忽略后续的。

设有

[html]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. <form>  
  2.     <input type="text" name="username" />  
  3.     <input type="text" name="password" />  
  4. </form>  

[javascript]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. jQuery("form").serialize(); //"username=&password="  
  2. jQuery("form").serializeArray(); //[{name:"username",value:""},{name:"password",value:""}]  
  3. jQuery("form").serializeObject(); //{username:"",password:""}  



20150125更新
===========
+ 此版本不再兼容IE8
+ 修复一个逻辑错误

[javascript]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. //work with jQuery 2.x  
  2. jQuery.prototype.serializeObject=function(){  
  3.     var hasOwnProperty=Object.prototype.hasOwnProperty;  
  4.     return this.serializeArray().reduce(function(data,pair){  
  5.         if(!hasOwnProperty.call(data,pair.name)){  
  6.             data[pair.name]=pair.value;  
  7.         }  
  8.         return data;  
  9.     },{});  
  10. };  



20150705更新
===========

+ 减少方法依赖,扩大兼容范围
+ 改用原生循环,提升代码性能

[javascript]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. //work with jQuery Compact 3.x  
  2. jQuery.prototype.serializeObject=function(){  
  3.     var a,o,h,i,e;  
  4.     a=this.serializeArray();  
  5.     o={};  
  6.     h=o.hasOwnProperty;  
  7.     for(i=0;i<a.length;i++){  
  8.         e=a[i];  
  9.         if(!h.call(o,e.name)){  
  10.             o[e.name]=e.value;  
  11.         }  
  12.     }  
  13.     return o;  
  14. };  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值