【发布时间】:2012-07-05 12:42:35
【问题描述】:
我想对Backbone.js 模型中的表单进行一些服务器前验证。为此,我需要将用户输入从表单转换为可用数据。 我找到了三种方法来做到这一点:
var input = $("#inputId").val();var input = $("form.login").serialize();var input = $("form.login").serializeArray();
不幸的是,没有一个提供我需要的良好的可重复和可开发的 JSON 对象。我已经查看了有关 StackOverflow 的几个问题,但只发现了一些额外的库。
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>
JavaScript
var formData = $("form.login").serializeObject();
console.log(formData);
输出
{
"name": "dev.pus",
"pass": "1234"
}
Backbone.js 模型
var user = new User(formData);
user.save();
【问题讨论】:
-
jQuery 有一个 JSON 插件:code.google.com/p/jquery-json,它不包含辅助方法。
-
.serializeArray()有什么问题? -
表单需要它,我只是想知道三个框架不提供表单映射器......
-
关于重复标记
This question already has an answer here::JSON不是JavaScript对象,它的序列化对象! -
@xdazz 也许他们想要 { "name": "value" } 而不是 { "name": "input_name", "value": "input_value" }
标签: jquery backbone.js underscore.js