使用jQuery将表单数据转换为JavaScript对象
如何将表单的所有元素转换为JavaScript对象使用jQuery将表单数据转换为JavaScript对象,javascript,jquery,json,serialization,Javascript,Jquery,Json,Serialization,如何将表单的所有元素转换为JavaScript对象 我希望有一些方法可以从我的表单自动构建JavaScript对象,而不必在每个元素上循环。我不想要由$('#formid').serialize()返回的字符串,也不希望通过$('#formid')返回映射。serializeArray()如果不检查每个元素,就真的无法做到这一点。您真正想知道的是“是否有其他人已经编写了将表单转换为JSON对象的方法?”类似于以下内容的内容应该可以工作——请注意,它只提供通过POST返回的表单元素(必须有名称)。
我希望有一些方法可以从我的表单自动构建JavaScript对象,而不必在每个元素上循环。我不想要由
$('#formid').serialize()返回的字符串代码>,也不希望通过$('#formid')返回映射。serializeArray()代码>如果不检查每个元素,就真的无法做到这一点。您真正想知道的是“是否有其他人已经编写了将表单转换为JSON对象的方法?”类似于以下内容的内容应该可以工作——请注意,它只提供通过POST返回的表单元素(必须有名称)。这是未测试的
function formToJSON( selector )
{
var form = {};
$(selector).find(':input[name]:enabled').each( function() {
var self = $(this);
var name = self.attr('name');
if (form[name]) {
form[name] = form[name] + ',' + self.val();
}
else {
form[name] = self.val();
}
});
return form;
}
已经做到了。您只需将数据转换为所需格式:
function objectifyForm(formArray){
//序列化数据函数
var returnArray={};
对于(变量i=0;i
注意与实际输入同名的隐藏字段,因为它们将被覆盖。我更喜欢这种方法,因为:您不必迭代2个集合,如果需要,您可以获取除“名称”和“值”以外的内容,并且您可以在将值存储到对象中之前对其进行清理(例如,如果您有不希望存储的默认值)
像这样使用:
var obj = $.formObject($("#someForm"));
仅在Firefox中测试。好的,我知道这已经有了一个非常高投票率的答案,但最近又有一个,我也被引导到了这个问题。我也想提供我的解决方案,因为它比公认的解决方案有一个优势:可以包含禁用的表单元素(这有时很重要,取决于用户界面的功能)
以下是我的答案:
最初,我们使用jQuery的serializeArray()
方法,但不包括禁用的表单元素。我们通常会禁用与页面上其他源“同步”的表单元素,但我们仍然需要在序列化对象中包含数据。因此serializeArray()
已退出。我们使用:input
选择器获取给定容器中的所有输入元素(启用和禁用),然后使用$.map()
创建对象
var inputs = $("#container :input");
var obj = $.map(inputs, function(n, i)
{
var o = {};
o[n.name] = $(n).val();
return o;
});
console.log(obj);
请注意,要使其正常工作,每个输入都需要一个name
属性,该属性将是结果对象的属性名称
我们需要创建一个结构为.NET IDictionary的对象,所以我们使用了以下方法:(我在这里提供它,以防有用)
我喜欢这两种解决方案,因为它们都是$.map()
函数的简单用法,而且您可以完全控制选择器(因此,最终在结果对象中包含哪些元素)。此外,不需要额外的插件。简单的老jQuery。我发现Tobias Cohen的代码有问题(我没有足够的点数来直接对其进行评论),否则这对我来说很有用。如果您有两个同名的select选项,它们的值都为“”,则原始代码将生成“name”:“”,而不是“name”:[“”,“”]
我认为这可以通过在第一个if条件中添加“| | o[this.name]==””来解决:
$.fn.serializeObject = function()
{
var o = {};
var a = this.serializeArray();
$.each(a, function() {
if (o[this.name] || o[this.name] == '') {
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;
};
Tobias Cohen解决方案的固定版本。此解决方案正确处理虚假值,如0
和'
还有一个咖啡脚本版本,方便您编写代码:
jQuery.fn.serializeObject = ->
arrayData = @serializeArray()
objectData = {}
$.each arrayData, ->
if @value?
value = @value
else
value = ''
if objectData[@name]?
unless objectData[@name].push
objectData[@name] = [objectData[@name]]
objectData[@name].push value
else
objectData[@name] = value
return objectData
所有这些答案对我来说都太过分了。为了简单起见,有一点要说。只要您的所有表单输入都设置了name属性,这应该可以正常工作
我喜欢samuels版本,但我相信它有一个小错误
{“coreSKU”:“PCGUYJS”,“name_de”:“whatever”
不如
[{“coreSKU”:“PCGUYJS”},{“name_de”:“whatever”}
因此,IMO的功能应为:
App.toJson = function( selector ) {
var o = {};
$.map( $( selector ), function( n,i )
{
o[n.name] = $(n).val();
});
return o;
}
并将其包装在数据数组中(正如通常所预期的那样),最后将其作为astring发送
stringify({data:App.toJson('#cropform:input'))
对于精简版的stringify查看,对于每个可能发生的事件覆盖的版本,查看。这应该涵盖所有内容:)我发现所选解决方案存在问题
使用具有基于数组的名称的表单时,jQuery serializeArray()函数实际上会失效
我有一个PHP框架,它使用基于数组的字段名,允许同一表单在多个视图中多次放在同一页面上。这可以方便地在同一页面上添加、编辑和删除,而不会与表单模型发生冲突
因为我想在不需要去掉这个绝对基本功能的情况下对表单进行序列化,所以我决定编写自己的seralizeArray():
请注意:这也适用于表单提交()之外,因此,如果在代码的其余部分出现错误,则如果在链接按钮上显示“保存更改”,表单将不会提交
还请注意,此函数不应仅用于验证表单以收集发送到服务器端进行验证的数据。使用如此弱且大量分配的代码将导致等。像boss一样将表单转换为JSON
电流源为和
$bower安装jquery序列化对象
下面的代码现在已被弃用。
下面的代码可以处理所有类型的输入名称;并按照预期处理它们
例如:
<!-- All of these will work! -->
<input name="honey[badger]" value="a">
<input name="wombat[]" value="b">
<input name="hello[panda][]" value="c">
<input name="animals[0][name]" value="d">
<input name="animals[0][breed]" value="e">
<input name="crazy[1][][wonky]" value="f">
<input name="dream[as][vividly][as][you][can]" value="g">
用法
魔法(JavaScript)
将任何东西变成对象(未经过单元测试)
在
此函数应处理多维数组以及具有相同名称的多个元素
到目前为止,我已经使用了几年:
jQuery.fn.serializeJSON=function() {
var json = {};
jQuery.map(jQuery(this).serializeArray(), function(n, i) {
var _ = n.name.indexOf('[');
if (_ > -1) {
var o = json;
_name = n.name.replace(/\]/gi, '').split('[');
for (var i=0, len=_name.length; i<len; i++) {
if (i == len-1) {
if (o[_name[i]]) {
if (typeof o[_name[i]] == 'string') {
o[_name[i]] = [o[_name[i]]];
}
o[_name[i]].push(n.value);
}
else o[_name[i]] = n.value || '';
}
else o = o[_name[i]] = o[_name[i]] || {};
}
}
else {
if (json[n.name] !== undefined) {
if (!json[n.name].push) {
json[n.name] = [json[n.name]];
}
json[n.name].push(n.value || '');
}
else json[n.name] = n.value || '';
}
});
return json;
};
jQuery.fn.serializeJSON=function(){
var json={};
map(jQue
$('form.myform').submit(function () {
var $this = $(this)
, viewArr = $this.serializeArray()
, view = {};
for (var i in viewArr) {
view[viewArr[i].name] = viewArr[i].value;
}
//Do stuff with view object here (e.g. JSON.stringify?)
});
App.toJson = function( selector ) {
var o = {};
$.map( $( selector ), function( n,i )
{
o[n.name] = $(n).val();
});
return o;
}
var $vals = {};
$("#video_edit_form input").each(function(i){
var name = $(this).attr("name").replace(/editSingleForm\[/i, '');
name = name.replace(/\]/i, '');
switch($(this).attr("type")){
case "text":
$vals[name] = $(this).val();
break;
case "checkbox":
if($(this).attr("checked")){
$vals[name] = $(this).val();
}
break;
case "radio":
if($(this).attr("checked")){
$vals[name] = $(this).val();
}
break;
default:
break;
}
});
<!-- All of these will work! -->
<input name="honey[badger]" value="a">
<input name="wombat[]" value="b">
<input name="hello[panda][]" value="c">
<input name="animals[0][name]" value="d">
<input name="animals[0][breed]" value="e">
<input name="crazy[1][][wonky]" value="f">
<input name="dream[as][vividly][as][you][can]" value="g">
$('#my-form').serializeObject();
(function($){
$.fn.serializeObject = function(){
var self = this,
json = {},
push_counters = {},
patterns = {
"validate": /^[a-zA-Z][a-zA-Z0-9_]*(?:\[(?:\d*|[a-zA-Z0-9_]+)\])*$/,
"key": /[a-zA-Z0-9_]+|(?=\[\])/g,
"push": /^$/,
"fixed": /^\d+$/,
"named": /^[a-zA-Z0-9_]+$/
};
this.build = function(base, key, value){
base[key] = value;
return base;
};
this.push_counter = function(key){
if(push_counters[key] === undefined){
push_counters[key] = 0;
}
return push_counters[key]++;
};
$.each($(this).serializeArray(), function(){
// Skip invalid keys
if(!patterns.validate.test(this.name)){
return;
}
var k,
keys = this.name.match(patterns.key),
merge = this.value,
reverse_key = this.name;
while((k = keys.pop()) !== undefined){
// Adjust reverse_key
reverse_key = reverse_key.replace(new RegExp("\\[" + k + "\\]$"), '');
// Push
if(k.match(patterns.push)){
merge = self.build([], self.push_counter(reverse_key), merge);
}
// Fixed
else if(k.match(patterns.fixed)){
merge = self.build([], k, merge);
}
// Named
else if(k.match(patterns.named)){
merge = self.build({}, k, merge);
}
}
json = $.extend(true, json, merge);
});
return json;
};
})(jQuery);
<script type="text/javascript">
string = {};
string.repeat = function(string, count)
{
return new Array(count+1).join(string);
}
string.count = function(string)
{
var count = 0;
for (var i=1; i<arguments.length; i++)
{
var results = string.match(new RegExp(arguments[i], 'g'));
count += results ? results.length : 0;
}
return count;
}
array = {};
array.merge = function(arr1, arr2)
{
for (var i in arr2)
{
if (arr1[i] && typeof arr1[i] == 'object' && typeof arr2[i] == 'object')
arr1[i] = array.merge(arr1[i], arr2[i]);
else
arr1[i] = arr2[i]
}
return arr1;
}
array.print = function(obj)
{
var arr = [];
$.each(obj, function(key, val) {
var next = key + ": ";
next += $.isPlainObject(val) ? array.print(val) : val;
arr.push( next );
});
return "{ " + arr.join(", ") + " }";
}
node = {};
node.objectify = function(node, params)
{
if (!params)
params = {};
if (!params.selector)
params.selector = "*";
if (!params.key)
params.key = "name";
if (!params.value)
params.value = "value";
var o = {};
var indexes = {};
$(node).find(params.selector+"["+params.key+"]").each(function()
{
var name = $(this).attr(params.key),
value = $(this).attr(params.value);
var obj = $.parseJSON("{"+name.replace(/([^\[]*)/, function()
{
return '"'+arguments[1]+'"';
}).replace(/\[(.*?)\]/gi, function()
{
if (arguments[1].length == 0)
{
var index = arguments[3].substring(0, arguments[2]);
indexes[index] = indexes[index] !== undefined ? indexes[index]+1 : 0;
return ':{"'+indexes[index]+'"';
}
else
return ':{"'+escape(arguments[1])+'"';
})+':"'+value.replace(/[\\"]/gi, function()
{
return "\\"+arguments[0];
})+'"'+string.repeat('}', string.count(name, ']'))+"}");
o = array.merge(o, obj);
});
return o;
}
</script>
$(document).ready(function()
{
console.log(array.print(node.objectify($("form"), {})));
console.log(array.print(node.objectify($("form"), {selector: "select"})));
});
<form>
<input name='input[a]' type='text' value='text'/>
<select name='input[b]'>
<option>select</option>
</select>
<input name='otherinput[c][a]' value='a'/>
<input name='otherinput[c][]' value='b'/>
<input name='otherinput[d][b]' value='c'/>
<input name='otherinput[c][]' value='d'/>
<input type='hidden' name='anotherinput' value='hidden'/>
<input type='hidden' name='anotherinput' value='1'/>
<input type='submit' value='submit'/>
</form>
{ input: { a: text, b: select }, otherinput: { c: { a: a, 0: b, 1: d }, d: { b: c } }, anotherinput: 1 }
{ input: { b: select } }
jQuery.fn.serializeJSON=function() {
var json = {};
jQuery.map(jQuery(this).serializeArray(), function(n, i) {
var _ = n.name.indexOf('[');
if (_ > -1) {
var o = json;
_name = n.name.replace(/\]/gi, '').split('[');
for (var i=0, len=_name.length; i<len; i++) {
if (i == len-1) {
if (o[_name[i]]) {
if (typeof o[_name[i]] == 'string') {
o[_name[i]] = [o[_name[i]]];
}
o[_name[i]].push(n.value);
}
else o[_name[i]] = n.value || '';
}
else o = o[_name[i]] = o[_name[i]] || {};
}
}
else {
if (json[n.name] !== undefined) {
if (!json[n.name].push) {
json[n.name] = [json[n.name]];
}
json[n.name].push(n.value || '');
}
else json[n.name] = n.value || '';
}
});
return json;
};
<places>
<place>
<name>Home</name>
<type>dwelling</type>
<activity>sleep</activity>
<activity>eat</activity>
<activity>watch TV</activity>
</place>
<place>...</place>
<place>...</place>
</places>
<form name="places">
<fieldset name="place">
<input type="text" name="name"/>
<select name="type">
<option value="dwelling">Dwelling</option>
<option value="restoration">Restoration</option>
<option value="sport">Sport</option>
<option value="administrative">Administrative</option>
</select>
<input type="text" name="activity"/>
<input type="text" name="activity"/>
<input type="text" name="activity"/>
</fieldset>
</form>
{'places':{
'place':[
{
'name': 'Home',
'type': 'dwelling',
'activity':[
'sleep',
'eat',
'watch TV'
]
},
{...},
{...}
]
}}
$.fn.toJSO = function () {
var obj = {},
$kids = $(this).children('[name]');
if (!$kids.length) {
return $(this).val();
}
$kids.each(function () {
var $el = $(this),
name = $el.attr('name');
if ($el.siblings("[name=" + name + "]").length) {
if (!/radio|checkbox/i.test($el.attr('type')) || $el.prop('checked')) {
obj[name] = obj[name] || [];
obj[name].push($el.toJSO());
}
} else {
obj[name] = $el.toJSO();
}
});
return obj;
};
$.post('script.php',('form').toJSO(), ...);
var values = $(this).serialize(),
attributes = {};
values.replace(/([^&]+)=([^&]*)/g, function (match, name, value) {
attributes[name] = value;
});
var data = {};
$(".form-selector").serializeArray().map(function(x){data[x.name] = x.value;});
<form id="myform">
<label>Name:</label>
<input type="text" name="name"/>
<label>Email</label>
<input type="text" name="email"/>
<label>Password</label>
<input type="password" name="password"/>
</form>
$('#myform').jsonify();
{"name":"Joe User","email":"joe@example.com","password":"mypass"}
$('#mybutton').click(function() {
$.post('/api/user', JSON.stringify($('#myform').jsonify()));
}
function form_to_json (selector) {
var ary = $(selector).serializeArray();
var obj = {};
for (var a = 0; a < ary.length; a++) obj[ary[a].name] = ary[a].value;
return obj;
}
{"myfield": "myfield value", "passwordfield": "mypasswordvalue"}
"validate": /^[a-zA-Z][a-zA-Z0-9_]*((?:\[(?:\d*|[a-zA-Z0-9_]+)\])*(?:\.)[a-zA-Z][a-zA-Z0-9_]*)*$/,
<input type="text" name="zooName" />
<input type="text" name="zooAnimals[0].name" />
_.object(_.map($('#myform').serializeArray(), _.values))
var frm = $(document.myform);
var data = JSON.stringify(frm.serializeArray());
$('#formid').serializeArray()
.reduce(function(a, x) { a[x.name] = x.value; return a; }, {});
$('form input, form select').toArray().reduce(function(m,e){m[e.name] = $(e).val(); return m;},{})
$('form').serializeArray().map(function(x){this[x.name] = x.value; return this;}.bind({}))[0]
"id=2&value=1&comment=ok" => Object { id: "2", value: "1", comment: "ok" }
const formData = new FormData(form);
let formDataJSON = {};
for (const [key, value] of formData.entries()) {
formDataJSON[key] = value;
}