如何将表单的所有元素转换为JavaScript对象?
我想有一些方法从我的表单中自动构建一个JavaScript对象,而不必遍历每个元素.我不想要返回的字符串,$('#formid').serialize();也不想要返回的地图$('#formid').serializeArray();
我想在Backbone.js模型中对表单进行一些服务器前验证.为此,我需要将表单中的用户输入转换为可用数据.我发现了三种方法:
var input = $("#inputId").val();var input = $("form.login").serialize();var input = $("form.login").serializeArray();不幸的是,没有一个提供我需要的良好的可重用和可开发的JSON对象.我已经查看了Stack Overflow上的几个问题,但我发现只有一些额外的库.
不是Underscore.js,当前的jQuery或Backbone.js提供了一个帮助方法吗?
我无法想象没有这种功能的要求.
HTML
<form class="login">
<label for="_user_name">username:</label>
<input type="text" id="_user_name" name="user[name]" value="dev.pus" />
<label for="_user_pass">password:</label>
<input type="password" id="_user_pass" name="user[pass]" value="1234" />
<button type="submit">login</button>
</form>
Run Code Online (Sandbox Code Playgroud)
JavaScript的
var formData = $("form.login").serializeObject();
console.log(formData);
Run Code Online (Sandbox Code Playgroud)
输出
{
"name": "dev.pus",
"pass": "1234"
}
Run Code Online (Sandbox Code Playgroud)
Backbone.js模型
var user = new User(formData);
user.save();
Run Code Online (Sandbox Code Playgroud)