带有Html Helper的条件html属性
我正在使用Html助手创建一个复选框。 在某些情况下,我想将disabled
属性添加到htmlAttribute对象。 我有以下代码:
@if (Model.IsAuthorized) { @Html.CheckBoxFor(x => @Model.Property, new { @class = "input-class" }) } else { @Html.CheckBoxFor(x => @Model.Property, new { @class = "input-class", @disabled = "disabled" }) }
我想让这段代码更简洁。 有没有办法在一行中有条件地添加某些html属性/没有块条件?
虽然你可以使用
@Html.CheckBoxFor(m => m.Property, Model.IsAuthorized ? (object)new { @class = "input-class", disabled = "disabled" } : (object)new { @class = "input-class"});
要在一行代码中执行此操作,在您的情况下,可能会导致模型绑定失败。
CheckBoxFor()
方法生成2个输入,一个value="True"
的复选框和一个value="False"
的隐藏输入。 如果Property
的初始值为true
且IsAuthorized
为true
则结果是复选框被禁用且不会发布值。 但是隐藏的输入将被提交并绑定到您的模型,导致Property
为false
(当它应该为true
)
为了正确处理模型绑定,您需要if
块
@if (Model.IsAuthorized) { @Html.CheckBoxFor(x => m.Property, new { @class = "input-class" }) } else { @Html.HiddenFor(m => m.Property) // necessary to post back the initial value }