1

我有一个名为 W2_Sent 的字段,它被定义为 (bit,null)

在我看来,我有以下将其显示为复选框:

     <div class="editor-label"  style="width: 10em">                        
       @Html.Label("W2 Sent")
     </div>
     <div class="editor-field">
       @Html.EditorFor(model => model.W2_Sent)
       @Html.ValidationMessageFor(model => model.W2_Sent)
     </div>

如果我检查它,我会收到错误

值 'checked' 对 W2_Sent 无效

      [HttpPost]
      public ActionResult Create(Employee emp)
      {

        foreach (ModelState modelState in ViewData.ModelState.Values)
        {
            foreach (ModelError error in modelState.Errors)
            {

                string s = "error";

            }

        }

我能够在上面看到的 foreach 循环中捕获错误..

为什么我得到“检查”的价值是无效的

4

3 回答 3

12

要在表单中显示复选框,您应该始终使用@Html.CheckBox/CheckBoxFor而不是<input type="checkbox" name="gender" />. 当您使用@Html.CheckBox/CheckBoxForASP.NET MVC 生成一个隐藏字段,该字段具有一个布尔值,这就是将绑定到您的模型属性的内容。

当您直接使用 html 部分时,浏览器会将字段的值发布为字符串“已检查”(如果是),并且在引发错误的模型绑定中。

于 2012-07-26T03:15:13.393 回答
4

我已经这样做了。为 CheckBoxFor 编写您自己的 ExtensionMethod。诀窍是复选框中“value”=“true”的静态值和隐藏字段中的“value”“false”。如前所述,不会发回值为 false 的复选框。在这种情况下,将采用隐藏字段的值。当用户选中该复选框时,新的“true”值将覆盖隐藏字段中的“false”。

    public static MvcHtmlString CheckboxForMetro<TModel, TValue>(this HtmlHelper<TModel> html, Expression<Func<TModel, TValue>> expression, int offset = 3)
    {
        TagBuilder tblabel = new TagBuilder("label");
        tblabel.AddCssClass("checkbox offset" + offset.ToString());

        TagBuilder tbinput = new TagBuilder("input");
        tbinput.Attributes.Add("type", "checkbox");
        tbinput.Attributes.Add("id", GetPropertyNameFromLambdaExpression(html, expression));
        tbinput.Attributes.Add("name", GetPropertyNameFromLambdaExpression(html, expression));
        tbinput.Attributes.Add("value", "true");
        tbinput.MergeAttributes(GetPropertyValidationAttributes(html, expression, null));
        if (GetPropertyValueFromLambdaExpression(html, expression) == "True") tbinput.Attributes.Add("checked", "checked");

        TagBuilder tbhidden = new TagBuilder("input");
        tbhidden.Attributes.Add("type", "hidden");
        tbhidden.Attributes.Add("value", "false");
        tbhidden.Attributes.Add("name", GetPropertyNameFromLambdaExpression(html, expression));

        TagBuilder tbspan = new TagBuilder("span");
        //tbspan.AddCssClass("span" + spanLabel.ToString());
        tbspan.InnerHtml = GetPropertyDisplayNameFromLambdaExpression(html, expression);
        tblabel.InnerHtml = tbinput.ToString() + tbspan.ToString() + tbhidden.ToString();

        return new MvcHtmlString(tblabel.ToString());
    }

它是 Metro UI CSS 的 ExtensionMethod,位于http://metroui.org.ua

这是获取值、显示名称、属性名称和验证属性的代码

    private static string GetPropertyDisplayNameFromLambdaExpression<TModel, TValue>(HtmlHelper<TModel> html, Expression<Func<TModel, TValue>> expression)
    {
        ModelMetadata metadata = ModelMetadata.FromLambdaExpression(expression, html.ViewData);
        string htmlFieldName = ExpressionHelper.GetExpressionText(expression);

        return metadata.DisplayName ?? metadata.PropertyName ?? htmlFieldName.Split('.').Last() ?? "Geen tekst";
    }

    private static string GetPropertyValueFromLambdaExpression<TModel, TValue>(HtmlHelper<TModel> html, Expression<Func<TModel, TValue>> expression)
    {
        string value = string.Empty;
        TModel model = html.ViewData.Model;
        if (model != null)
        {
            var expr = expression.Compile().Invoke(model);
            if (expr != null)
            {
                value = expr.ToString();
            }
        }
        return value;
    }

    private static string GetPropertyNameFromLambdaExpression<TModel, TValue>(HtmlHelper<TModel> html, Expression<Func<TModel, TValue>> expression)
    {
        ModelMetadata metadata = ModelMetadata.FromLambdaExpression(expression, html.ViewData);
        return metadata.PropertyName;
    }

    private static IDictionary<string, object> GetPropertyValidationAttributes<TModel, TValue>(HtmlHelper<TModel> html, Expression<Func<TModel, TValue>> expression, IDictionary<string, object> htmlAttributes)
    {
        ModelMetadata metadata = ModelMetadata.FromLambdaExpression(expression, html.ViewData);
        IDictionary<string, object> validationAttributes = html.GetUnobtrusiveValidationAttributes(ExpressionHelper.GetExpressionText(expression), metadata);
        if (htmlAttributes == null)
        {
            htmlAttributes = validationAttributes;
        }
        else
        {
            htmlAttributes = htmlAttributes.Concat(validationAttributes).ToDictionary(k => k.Key, v => v.Value);
        }
        return htmlAttributes;
    }

我希望这对其他人有帮助。

于 2012-11-27T13:04:04.320 回答
0

就我而言,我使用了一些不允许我使用 HTMLhelper 的样式库。因此,如果它对任何人有用,一个简单的解决方案是在提交表单时使用 jQuery,只需将检查值分配给输入,如下所示。

$("#myForm").submit(function (e) {
    $("#myCheckBoxInput").val($("#myCheckBoxInput").prop("checked"))
})

于 2019-10-18T16:01:05.597 回答