如何将表单中的复选框序列化为Json数据

Posted

技术标签:

【中文标题】如何将表单中的复选框序列化为Json数据【英文标题】:How to serialize the checkbox in a form into Json data 【发布时间】:2012-08-19 02:13:51 【问题描述】:

我们知道,在 MVC 中,CheckBoxFor 将生成带有 value="true"checkbox 和带有 value=falsehidden。两个输入控件将共享相同的名称。

这是非常合理的,因为如果未选中该框,表单将能够 POST 错误值。当复选框返回 true 时,模型绑定器将忽略隐藏的输入。

但是现在我已经覆盖了表单提交事件,以便将表单数据以 JSON 格式发送到 WebAPI 控制器。

在序列化表单数据时,没有正确解析复选框和隐藏的关系的机制。因此,未选中时,它返回一个false,这没关系。但是当检查时,它返回一个true, false 而不是true,因为serializeArray() 函数会遍历每个input 并找到两个值同名。

问题是:纠正它的最佳方法是什么?

【问题讨论】:

ASP.Net MVC 4's WebAPI does not bind check boxes correctly? 的可能重复项 【参考方案1】:

我对这个问题的解决方案是编写我自己的 htmlHelper 方法,该方法呈现单个 标记。任何其他解决方案似乎都太老套了。

如果您在完成该任务时需要任何帮助,可以使用 dotPeek 或 .NET Reflector 查看 Microsoft 团队如何创建 HtmlHelper.CheckboxFor 方法。

当“bool”参数没有匹配的参数发送到控制器(未选中的复选框不发送任何值)时,采用 2 标记方法来防止 MVC 操作参数引发异常。

【讨论】:

以上是关于如何将表单中的复选框序列化为Json数据的主要内容,如果未能解决你的问题,请参考以下文章

HTML/Javascript 表单 如何将表单数据序列化为 JSON 并在类中显示?

将表单数据序列化为 JSON [重复]

如何将form内的表单序列化为json字符串

使用动态输入将表单数据序列化为 JSON

将多维表单数据序列化为 JSON 对象数组以使用 application/json

将表单序列化为没有空值的 json