JQuery中serialize() 序列化


Posted in Javascript onMarch 13, 2015

本文导读:在jQuery中,当我们使用ajax时,常常需要拼装input数据以键值对(Key/Value)的形式发送到服务器,用JQuery的serialize方法可以轻松的完成这个工作,使用这个方法可以将表单序列化为键值对(key1=value1&key2=value2…)后提交。下面介绍JQuery中serialize()的用法

一、serialize()定义和用法:

serialize()方法通过序列化表单值,创建标准的URL编码文本字符串,它的操作对象是代表表单元素集合的jQuery 对象。你可以选择一个或多个表单元素(比如input或文本框),或者 form 元素本身。序列化的值可在生成 AJAX 请求时用于 URL 查询字符串中。

语法:

$(selector).serialize()

详细说明

1、.serialize() 方法创建以标准 URL 编码表示的文本字符串。它的操作对象是代表表单元素集合的 jQuery 对象。

2、.serialize() 方法可以操作已选取个别表单元素的 jQuery 对象,比如 <input>, <textarea> 以及 <select>。不过,选择 <form> 标签本身进行序列化一般更容易些

3、只会将”成功的控件“序列化为字符串。如果不使用按钮来提交表单,则不对提交按钮的值序列化。如果要表单元素的值包含到序列字符串中,元素必须使用 name 属性。

4、form里面的name不能够用 Js、jquery里的关键字。

例如:length

<form id="form1">

   <input name="length" type="text" value="pipi" />

   <input name="blog" type="text" value="blue submarine" />

</form>

//使用:$("#form1").serialize();

上面则获取不到值。

二、JQuery中serialize()实例

1、ajax serialize()

$.ajax({

    type: "POST",

    dataType: "json",

    url:ajaxCallBack,

    data:$('#myForm').serialize(),// 要提交表单的ID

    success: function(msg){

        alert(msg);

    }

});

2、serialize() 序列化表单实例

 <script src="jquery-1.7.min。js"></script>

<script>

$(function(){

   $("#submit").click(function(){

     alert($("#myForm").serialize());

   });

});

</script>

<form id="myForm">

昵称 <input type="text" name="username" value="admin" /><br />

密码 <input type="password" name="password" value="admin123" /><br />

<input type="button" id="submit" value="序列化表单" /> 

</form>

点击按钮之后弹出:

username=admin&password=admin123

三、serialize是用param方法对serializeArray的一个简单包装

1、$.param()

$.param()方法是serialize()方法的核心,用来对一个数组或对象按照key/value进行序列化。

param方法的js代码

 param: function( a ) {

        ///    <summary>

        ///        This method is internal.  Use serialize() instead.

        ///    </summary>

        ///    <param name="a" type="Map">A map of key/value pairs to serialize into a string.</param>'

        ///    <returns type="String" />

        ///    <private />

        var s = [ ];

        function add( key, value ){

            s[ s.length ] = encodeURIComponent(key) + '=' + encodeURIComponent(value);

        };

        // If an array was passed in, assume that it is an array

        // of form elements

        if ( jQuery.isArray(a) || a.jquery )

            // Serialize the form elements

            jQuery.each( a, function(){

                add( this.name, this.value );

            });

        // Otherwise, assume that it's an object of key/value pairs

        else

            // Serialize the key/values

            for ( var j in a )

                // If the value is an array then the key names need to be repeated

                if ( jQuery.isArray(a[j]) )

                    jQuery.each( a[j], function(){

                        add( j, this );

                    });

                else

                    add( j, jQuery.isFunction(a[j]) ? a[j]() : a[j] );

        // Return the resulting serialization

        return s.join("&").replace(/%20/g, "+");

    }

例如

var obj = {a:1,b:2,c:3};

var k = $.param(obj);

alert(k);    //输出a=1&b=2&c=3

2、serializeArray

serializeArray方法是将一个表单当中的各个字段序列化成一个数组

serializeArray方法的jquery定义

serializeArray: function() {

        ///    <summary>

        ///        Serializes all forms and form elements but returns a JSON data structure.

        ///    </summary>

        ///    <returns type="String">A JSON data structure representing the serialized items.</returns>

        return this.map(function(){

            return this.elements ? jQuery.makeArray(this.elements) : this;

        })

        .filter(function(){

            return this.name && !this.disabled &&

                (this.checked || /select|textarea/i.test(this.nodeName) ||

                    /text|hidden|password|search/i.test(this.type));

        })

        .map(function(i, elem){

            var val = jQuery(this).val();

            return val == null ? null :

                jQuery.isArray(val) ?

                    jQuery.map( val, function(val, i){

                        return {name: elem.name, value: val};

                    }) :

                    {name: elem.name, value: val};

        }).get();

    }

serializeArray数据例子

[ {   name : username,   value : 中国   }, {   name : password,   value : xxx  }]

以上就是本文所述的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
通用javascript脚本函数库 方便开发
Oct 13 Javascript
解决jquery submit()提交表单提示:f[s] is not a function
Jan 23 Javascript
如何使Chrome控制台支持多行js模式——意外发现
Jun 13 Javascript
jquery ajax 简单范例(界面+后台)
Nov 19 Javascript
JS 对象属性相关(检查属性、枚举属性等)
Apr 05 Javascript
JS实现支持Ajax验证的表单插件
Mar 24 Javascript
vue.js入门教程之绑定class和style样式
Sep 02 Javascript
vue toggle做一个点击切换class(实例讲解)
Mar 13 Javascript
vue+jquery+lodash实现滑动时顶部悬浮固定效果
Apr 28 jQuery
Vue 页面权限控制和登陆验证功能的实例代码
Jun 20 Javascript
详解解决小程序中webview页面多层history返回问题
Aug 20 Javascript
Vue中消息横向滚动时setInterval清不掉的问题及解决方法
Aug 23 Javascript
JavaScript中通过prototype属性共享属性和方法的技巧实例
Mar 13 #Javascript
JQuery中$.each 和$(selector).each()的区别详解
Mar 13 #Javascript
JavaScript实现判断图片是否加载完成的3种方法整理
Mar 13 #Javascript
JavaScript检查弹出窗口是否被阻拦的方法技巧
Mar 13 #Javascript
JavaScript中常用的六种互动方法示例
Mar 13 #Javascript
jQuery.position()方法获取不到值的安全替换方法
Mar 13 #Javascript
检测一个函数是否是JavaScript原生函数的小技巧
Mar 13 #Javascript
You might like
PHP的FTP学习(四)
2006/10/09 PHP
DedeCMS 核心类TypeLink.class.php摘要笔记
2010/04/07 PHP
php汉字转拼音的示例
2014/02/27 PHP
PHP_Cooikes不同页面无法传递的解决方法
2014/03/07 PHP
PHP连接和操作MySQL数据库基础教程
2014/09/29 PHP
php判断两个日期之间相差多少个月份的方法
2015/06/18 PHP
php删除二维数组中的重复值方法
2018/03/12 PHP
浅析PHP中的 inet_pton 网络函数
2019/12/16 PHP
详解phpstorm2020最新破解方法
2020/09/17 PHP
JS中彻底删除JSON对象组成的数组中的元素
2020/09/22 PHP
Jquery带搜索框的下拉菜单
2013/05/06 Javascript
Jquery easyUI 更新行示例
2014/03/06 Javascript
javascript页面渲染速度测试脚本分享
2014/04/15 Javascript
js闭包所用的场合以及优缺点分析
2015/06/22 Javascript
JS实现的自定义水平滚动字体插件完整实例
2016/06/17 Javascript
浅谈bootstrap使用中的一些问题以及解决过程
2016/10/18 Javascript
Bootstrap实现圆角、圆形头像和响应式图片
2016/12/14 Javascript
Vue开发过程中遇到的疑惑知识点总结
2017/01/20 Javascript
vue+elementUI实现表单和图片上传及验证功能示例
2019/05/14 Javascript
微信小程序使用字体图标的方法
2019/05/23 Javascript
Python中urllib2模块的8个使用细节分享
2015/01/01 Python
Python json模块使用实例
2015/04/11 Python
python解析xml文件实例分析
2015/05/27 Python
python 读取.csv文件数据到数组(矩阵)的实例讲解
2018/06/14 Python
详解python中的装饰器
2018/07/10 Python
Python实现实时数据采集新型冠状病毒数据实例
2020/02/04 Python
Python实现AI换脸功能
2020/04/10 Python
Melissa鞋马来西亚官方网站:MDreams马来西亚
2018/04/05 全球购物
有趣、实用和鼓舞人心的产品:Inspire Uplift
2019/11/05 全球购物
黑猩猩商店:The Chimp Store
2020/02/12 全球购物
测试工程师职业规划书
2014/02/06 职场文书
《蓝色的树叶》教学反思
2014/02/24 职场文书
工作鉴定评语
2014/05/04 职场文书
堂吉诃德读书笔记
2015/06/30 职场文书
2019年度行政文员工作计划范本!
2019/07/04 职场文书
Golang 1.18 多模块Multi-Module工作区模式的新特性
2022/04/11 Golang