javascript - 如何将表单序列化成这种json格式
本文介绍了javascript - 如何将表单序列化成这种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>
最好能无限嵌套的那种。
解决方案
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')//再自己处理下
这篇关于javascript - 如何将表单序列化成这种json格式的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文