js将form表单序列化[json字符串、数组、对象]

阅读更多

js将form表单序列化[json字符串、数组、对象]

(转至:http://www.cnblogs.com/bjlhx/p/6659392.html)

 

1.序列化为字符串

$("#Form").serialize();//name=zhangsan&sex=1&age=20  

2.序列化为数组

  var formData=$("#form").serializeArray();//[Object, Object, Object] 

自定义参数补充

  formData.push({"name": "psid", "value": $("#psid").val()});

3.序列化为对象

function getFormJson(form) {
        var o = {};
        var a = $(form).serializeArray();
        $.each(a, function () {
            if (o[this.name] !== undefined) {
                if (!o[this.name].push) {
                    o[this.name] = [o[this.name]];
                }
                o[this.name].push(this.value || '');
            } else {
                o[this.name] = this.value || '';
            }
        });
        return o;
    }

 

4.ajax传递普通数组

var deleteNum= [];//定义要传递的数组
deleteNum.push("1");
deleteNum.push("2");
deleteNum.push("3");//向数组中添加元素

$.ajax({
    type:"post",
    url:"deleteNum.do",
    data:{deleteNum:deleteNum},
    traditional: true,//必须指定为true
    success:function(data){
        if(data.success){
            deleteNum = [];
        }
    }
});

 后端代码

public AjaxResult deleteNum(String[] deleteNum){
    AjaxResult ajaxResult = new AjaxResult();
    //这个时候已经得到了deleteNum数组值
    return ajaxResult;
}

 

5.form表单提交自定义对象数组

 

 ajax提交

$("#form").serializeArray()

后端接收

public class FormList {
        private String table;
        private ArrayList userlist;
        
        public String getTable() {
            return table;
        }
        public void setTable(String table) {
            this.table = table;
        }
        public ArrayList getUserlist() {
            return userlist;
        }
        public void setUserlist(ArrayList userlist) {
            this.userlist= userlist;
        }
    }

 

public AjaxResult saveUpdateUser(FormList form){
    List userlist = list.getUserlist(); 
}

 

 

 

 

 

 

 

 

你可能感兴趣的:(js将form表单序列化[json字符串、数组、对象])