更多2014/8/24 来源:jquery学习浏览量:1671
学习标签: serialize
本文导读:在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

 
HTML 代码   复制

  1. <form id="form1">

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

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

  4. </form>

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

上面则获取不到值。

二、JQuery中serialize()实例

1、ajax serialize()

 
JScript 代码   复制
  1. $.ajax({
  2. type: "POST",
  3. dataType: "json",
  4. url:ajaxCallBack,
  5. data:$('#myForm').serialize(),// 要提交表单的ID
  6. success: function(msg){
  7. alert(msg);
  8. }
  9. });

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

HTML 代码   复制

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

  1. <script>
  2. $(function(){
  3. $("#submit").click(function(){
  4. alert($("#myForm").serialize());
  5. });
  6. });
  7. </script>
  8. <form id="myForm">
  9. 昵称 <input type="text" name="username" value="admin" /><br />
  10. 密码 <input type="password" name="password" value="admin123" /><br />
  11. <input type="button" id="submit" value="序列化表单" />
  12. </form>

点击按钮之后弹出:

username=admin&password=admin123

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

1、$.param()

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

param方法的js代码

 
JScript 代码   复制
  1. param: function( a ) {
  2. /// <summary>
  3. /// This method is internal. Use serialize() instead.
  4. /// </summary>
  5. /// <param name="a" type="Map">A map of key/value pairs to serialize into a string.</param>'
  6. /// <returns type="String" />
  7. /// <private />

  8. var s = [ ];

  9. function add( key, value ){
  10. s[ s.length ] = encodeURIComponent(key) + '=' + encodeURIComponent(value);
  11. };

  12. // If an array was passed in, assume that it is an array
  13. // of form elements
  14. if ( jQuery.isArray(a) || a.jquery )
  15. // Serialize the form elements
  16. jQuery.each( a, function(){
  17. add( this.name, this.value );
  18. });

  19. // Otherwise, assume that it's an object of key/value pairs
  20. else
  21. // Serialize the key/values
  22. for ( var j in a )
  23. // If the value is an array then the key names need to be repeated
  24. if ( jQuery.isArray(a[j]) )
  25. jQuery.each( a[j], function(){
  26. add( j, this );
  27. });
  28. else
  29. add( j, jQuery.isFunction(a[j]) ? a[j]() : a[j] );

  30. // Return the resulting serialization
  31. return s.join("&").replace(/%20/g, "+");
  32. }

例如

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定义

 
JScript 代码   复制
  1. serializeArray: function() {
  2. /// <summary>
  3. /// Serializes all forms and form elements but returns a JSON data structure.
  4. /// </summary>
  5. /// <returns type="String">A JSON data structure representing the serialized items.</returns>

  6. return this.map(function(){
  7. return this.elements ? jQuery.makeArray(this.elements) : this;
  8. })
  9. .filter(function(){
  10. return this.name && !this.disabled &&
  11. (this.checked || /select|textarea/i.test(this.nodeName) ||
  12. /text|hidden|password|search/i.test(this.type));
  13. })
  14. .map(function(i, elem){
  15. var val = jQuery(this).val();
  16. return val == null ? null :
  17. jQuery.isArray(val) ?
  18. jQuery.map( val, function(val, i){
  19. return {name: elem.name, value: val};
  20. }) :
  21. {name: elem.name, value: val};
  22. }).get();
  23. }

serializeArray数据例子

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

JQuery中serialize() 序列化的更多相关文章

  1. JQuery中serialize()

    一.serialize()定义和用法: serialize()方法通过序列化表单值,创建标准的URL编码文本字符串,它的操作对象是代表表单元素集合的jQuery 对象.你可以选择一个或多个表单元素(比 ...

  2. JQuery中serialize()、serializeArray()和param()方法示例介绍

    在项目中做form表单提交的时候,如果参数比较少,可以通过jquery一个个取得,但是当 form表参数很多的情况下,还是一一取得的话无疑是加大了工作量,那我们需要咱们获取到表单的所有参数呢,幸好,j ...

  3. JQuery中serialize()、serializeArray()和param()用法举例

    在javascript中,serialize()方法也是作用于一个JQuery对象,它能够将DOM元素内容序列化为字符串,serializeArray()方法不是返回字符串,而是将DOM元素序列化后, ...

  4. jquery $('#form1').serialize()序列化提交表单

    1.$("#form1").serialize() 把form表单的值序列化成一个字符串,如username=admin&password=admin123 <for ...

  5. jquery中ajax序列化提交form表单的几种方法。

    一,ajax主流的方法 $.ajax({ type: 'post', url: 'your url', data: $("form").serialize(), success: ...

  6. JQuery中serialize()方法的使用

  7. 关于jquery的serialize方法转换空格为+号的解决方法

    jquery的 serialize()方法,可以对表单项进行序列化,这本来是很方便的一个功能:但是实际使用中去发现了如下问题:例如:< textarea name="content&q ...

  8. jquery中使用serialize() 序列化表单时 中文乱码问题

    序列化中文时之所以乱码是因为.serialize()调用了encodeURLComponent方法将数据编码了 解决方法就是进行解码 1 原因:.serialize()自动调用了encodeURICo ...

  9. jQuery使用serialize()表单序列化时出现中文乱码问题&js获取url中的参数,并保证获取到的参数不乱码

    序列化中文时之所以乱码是因为.serialize()调用了encodeURLComponent方法将数据编码了 解决方法就是进行解码 原因:.serialize()自动调用了encodeURIComp ...

随机推荐

  1. java中文乱码解决之道(五)—–java是如何编码解码的

    原文出处:http://cmsblogs.com/?p=1491 在上篇博客中LZ阐述了java各个渠道转码的过程,阐述了java在运行过程中那些步骤在进行转码,在这些转码过程中如果一处出现问题就很有 ...

  2. 【Problem】Count and Say

    问题分析 题目理解:给定一个整数,如果相邻的几个数位数字是相同的,则输出重复出现的次数加上该数字本身:继续向后查找直到所有的数位处理完. 按照上述思路,则: input output 1 11 11 ...

  3. SQL事务与并发

    1.Transaction(事务)是什么: 事务是作为单一工作单元而执行的一系列操作.包括增删查改. 2.事务的种类: 事务分为显示事务和隐式事务: 隐式事务:就是平常我们使用每一条sql 语句就是一 ...

  4. javascript高级知识分析——实例化

    代码信息来自于http://ejohn.org/apps/learn/. new做了什么? function Ninja(){ this.name = "Ninja"; } var ...

  5. jquery结合highcharts插件显示实时数据动态曲线图

    效果如图所示: js代码如下: $(document).ready(function() { Highcharts.setOptions({ global: { useUTC: false }, co ...

  6. 21. 无法执行该操作,因为链接服务器”Server_202”的 OLE DB 访问接口 “SQLNCLI10″ 无法启动分布式事务”

    无法执行该操作,因为链接服务器”Server_202”的 OLE DB 访问接口 “SQLNCLI10″ 无法启动分布式事务” 原因:调用存储过程的方式有问题,必须用JDBC方式调用存储过程才可以正常 ...

  7. linux的nohup命令的用法。

    在应用Unix/Linux时,我们一般想让某个程序在后台运行,于是我们将常会 用 & 在程序结尾来让程序自动运行.比如我们要运行mysql在后台: /usr/local/mysql/bin/m ...

  8. J2SE知识点摘记(十四)

    1.        字符流 Reader是定义java的流式字符输入模式的抽象类,该类所有方法在出错的情况下都将引发IOException异常. Int read(char buffer[])     ...

  9. 转: HTML5新特性之Mutation Observer

    转: HTML5新特性之Mutation Observer Mutation Observer是什么 Mutation Observer(变动观察器)是监视DOM变动的接口.当DOM对象树发生任何变动 ...

  10. 原来ipad的浏览器也可以直接clip到evernote

    今天才发现是有方法通过邮件方式保存ipad上浏览的内容到evernote,之前以为要反复切换app来做到. 只要在toread.cc登记evernote对应帐号的邮箱,就可以根据toread返回到ev ...