相关疑难解决方法(0)

使用jQuery将表单数据转换为JavaScript对象

如何将表单的所有元素转换为JavaScript对象?

我想有一些方法从我的表单中自动构建一个JavaScript对象,而不必遍历每个元素.我不想要返回的字符串,$('#formid').serialize();也不想要返回的地图$('#formid').serializeArray();

javascript jquery serialization json

1580
推荐指数
21
解决办法
95万
查看次数

将表单数据序列化为JSON

我想在Backbone.js模型中对表单进行一些服务器前验证.为此,我需要将表单中的用户输入转换为可用数据.我发现了三种方法:

  1. var input = $("#inputId").val();
  2. var input = $("form.login").serialize();
  3. 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)

jquery backbone.js underscore.js

208
推荐指数
11
解决办法
55万
查看次数