我刚刚注意到Html.CheckBox(“foo”)生成2个输入而不是一个,有人知道为什么是这样吗?
<input id="foo" name="foo" type="checkbox" value="true" />
<input name="foo" type="hidden" value="false" />
我刚刚注意到Html.CheckBox(“foo”)生成2个输入而不是一个,有人知道为什么是这样吗?
<input id="foo" name="foo" type="checkbox" value="true" />
<input name="foo" type="hidden" value="false" />
当前回答
手动方法是这样的:
bool IsDefault = (Request.Form["IsDefault"] != "false");
其他回答
你可以尝试像这样初始化Model的构造函数:
public MemberFormModel() {
foo = true;
}
在您看来:
@html.Checkbox(...)
@html.Hidden(...)
这不是bug!它增加了在将表单提交到服务器后始终具有值的可能性。 如果你想用jQuery处理复选框输入字段,请使用prop方法(将'checked'属性作为参数传递)。 例子:$ (' # id ') .prop(检查)
如果未选中复选框,则不提交表单字段。这就是为什么隐藏字段中总是有假值的原因。如果你不选中复选框,表单仍然会有隐藏字段的值。这就是ASP。NET MVC处理复选框值。
如果您想确认这一点,请在表单上放置一个复选框,而不是Html。隐藏,但带有<input type="checkbox" name="MyTestCheckboxValue"></input>。不选中复选框,提交表单并查看服务器端发布的请求值。您将看到没有复选框值。如果你有隐藏字段,它将包含MyTestCheckboxValue项的假值。
在。net core 6中,我遇到了同样的问题,我尝试了@Kolazomai答案,它是有效的。
using Microsoft.AspNetCore.Mvc;
builder.Services.Configure<MvcViewOptions>(
opt=>opt.HtmlHelperOptions.CheckBoxHiddenInputRenderMode = Microsoft.AspNetCore.Mvc.Rendering.CheckBoxHiddenInputRenderMode.None
);
当复选框被选中并提交时,执行此操作
if ($('[name="foo"]:checked').length > 0)
$('[name="foo"]:hidden').val(true);
请参考