zoukankan      html  css  js  c++  java
  • jQuery

    原文地址

    http://blog.csdn.net/flashdelover/article/details/8185775

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

    //work with jQuery 1.x  
    jQuery.prototype.serializeObject=function(){  
        var obj=new Object();  
        $.each(this.serializeArray(),function(index,param){  
            if(!(param.name in obj)){  
                obj[param.name]=param.value;  
            }  
        });  
        return obj;  
    }; 

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

    设有

    <form>  
        <input type="text" name="username" />  
        <input type="text" name="password" />  
    </form> 

     
    jQuery("form").serialize(); //"username=&password="  
    jQuery("form").serializeArray(); //[{name:"username",value:""},{name:"password",value:""}]  
    jQuery("form").serializeObject(); //{username:"",password:""}  


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

    //work with jQuery 2.x  
    jQuery.prototype.serializeObject=function(){  
        var hasOwnProperty=Object.prototype.hasOwnProperty;  
        return this.serializeArray().reduce(function(data,pair){  
            if(!hasOwnProperty.call(data,pair.name)){  
                data[pair.name]=pair.value;  
            }  
            return data;  
        },{});  
    }; 


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

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

    //work with jQuery Compact 3.x  
    jQuery.prototype.serializeObject=function(){  
        var a,o,h,i,e;  
        a=this.serializeArray();  
        o={};  
        h=o.hasOwnProperty;  
        for(i=0;i<a.length;i++){  
            e=a[i];  
            if(!h.call(o,e.name)){  
                o[e.name]=e.value;  
            }  
        }  
        return o;  
    };  
  • 相关阅读:
    学生管理系统
    Selenium元素定位的30种方式
    python-- 多进程
    python 多线程的实现
    python 节省内存的for循环技巧
    python 生成器
    python 字符串编码检测
    opencv-python 图片的几何变换
    opencv-python --图像处理
    目标检测
  • 原文地址:https://www.cnblogs.com/jcz1206/p/7171723.html
Copyright © 2011-2022 走看看