首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >将序列化表单的数据转换为json对象

将序列化表单的数据转换为json对象
EN

Stack Overflow用户
提问于 2014-04-25 15:43:36
回答 5查看 102.7K关注 0票数 34

我有一个cshtml,如下所示

代码语言:javascript
复制
@using (Html.BeginForm("Save", "Plans", FormMethod.Post, new { @class = "form-horizontal", id = "floorplan-form" }))
{
            @Html.TextBoxFor(m => m.FloorPlan.Name, new { placeholder = "Enter text", @class = "form-control" })

            @Html.DropDownListFor(m => m.FloorPlan.GroupId, new SelectList(Model.FloorPlanGroups, "Id", "Name"))             
}

在我的javascript (在一个单独的javascript文件中)中,我试图序列化这个表单并将其转换成一个JSON对象。

代码语言:javascript
复制
var formData = $("#floorplan-form").serialize();
console.info(formData);

打印输出

代码语言:javascript
复制
FloorPlan.Name=Test&FloorPlan.GroupId=15 

代码语言:javascript
复制
var formData = $("#floorplan-form").serializeArray();
console.info(formData);

给了我:

我试过这样做

代码语言:javascript
复制
var formData = JSON.parse($("#floorplan-form").serializeArray());

但是我得到了这个错误:

代码语言:javascript
复制
Uncaught SyntaxError: Unexpected token o 
EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2014-04-25 16:08:56

更改您的语句

代码语言:javascript
复制
var formData = JSON.parse($("#floorplan-form").serializeArray());

使用

代码语言:javascript
复制
var formData = JSON.stringify(jQuery('#frm').serializeArray()); // store json string

代码语言:javascript
复制
var formData = JSON.parse(JSON.stringify(jQuery('#frm').serializeArray())) // store json object
票数 46
EN

Stack Overflow用户

发布于 2015-03-08 20:28:20

使用下面的代码!

代码语言:javascript
复制
    var data = $("form").serialize().split("&");
    console.log(data);
    var obj={};
    for(var key in data)
    {
        console.log(data[key]);
        obj[data[key].split("=")[0]] = data[key].split("=")[1];
    }

    console.log(obj);
票数 23
EN

Stack Overflow用户

发布于 2017-06-01 18:43:45

代码语言:javascript
复制
function jQFormSerializeArrToJson(formSerializeArr){
 var jsonObj = {};
 jQuery.map( formSerializeArr, function( n, i ) {
     jsonObj[n.name] = n.value;
 });

 return jsonObj;
}

使用此函数。这只适用于jquery。

代码语言:javascript
复制
var serializedArr = $("#floorplan-form").serializeArray();

var properJsonObj = jQFormSerializeArrToJson(serializedArr);
票数 11
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23287067

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档