如何将表单序列化成这种json格式

这个是想要结果

data{

info: {
    sex: 12,
    name: "张珊",
    address: "广东河源"
},
obj: [
    {
        sex: 12,
        name: "张珊",
        address: "广东河源"
    },{
        sex: 11,
        name: "李四",
        address: "广东广州"
    }
],
array: [255,22,22]

}

html的格式可以是这样子的

<form id="test">
    //这个是第一种格式的
    <input type="text" value="12" name="info#sex">
    <input type="text" value="张珊" name="info#name">
    <input type="text" value="广东河源" name="info#address">
    
    第二种格式不知道怎么搞
    
    //这个是第三种格式的
    <input type="checkbox" name="check[]" value="男" checked> 男
    <input type="checkbox" name="check[]" value="女" checked> 女
    <button type="button" id="button-sub">submit</button>
</form>

最好能无限嵌套的那种。

阅读 3.4k
2 个回答

serializeArray

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;
}
$json = getFormJson('#test')//再自己处理下

读取每一项表单项,然后去构造一个json呀,然后这种功能如果常用的话,自己封装成一个函数,可以根据name属性的格式自动构造

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题