jQuery序列化表单 serialize() serializeArray()

jQuery序列化表单 serialize() serializeArray()

1、serialize()方法

描述:序列化表单内容为字符串,用于Ajax请求。

格式:var data = $(form).serialize();
 

2.serializeArray()方法

描述:序列化表单元素(类似'.serialize()'方法)返回JSON数据结构数据。

注意,此方法返回的是JSON对象而非JSON字符串。需要使用插件或者第三方库进行字符串化操作。

格式:var jsonData = $(form).serializeArray();

在使用ajax提交表单数据时,以上两种方法都可以将data参数设置为$(form).serialize()或$(form).serializeArray()。


Demo

姓名:  
性别:  男  女
年龄:  
 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

$(function() {

   $(#ajaxBtn).click(function() {

    var params1 = $(#myform).serialize();

    var params2 = $(#myform).serializeArray();

    console.log(params1);  //name=zhangsan&sex=1&age=20

    console.log(params2);  //[Object, Object, Object]

    $.ajax( {

        type : POST,

        url : RegisterAction.action,

        data : params1,

        success : function(msg) {

            alert(success:  + msg);

        }

    });

   })

})

从下图中可以看出两种方法的不同

 

/

 

1.serialize()方法

  格式:var data = $("form").serialize();

  功能:将表单内容序列化成一个字符串。

  这样在ajax提交表单数据时,就不用一一列举出每一个参数。只需将data参数设置为 $("form").serialize() 即可。

2.serializeArray()方法

  格式:var jsonData = $("form").serializeArray();

  功能:将页面表单序列化成一个JSON结构的对象。注意不是JSON字符串。

  比如,[{"name":"lihui", "age":"20"},{...}] 获取数据为 jsonData[0].name

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章