包含 Razor 语句的 MvcHtmlString



我发现自己经常重复这个代码块......

        <div class="form-group">
            <div class="col-sm-3 control-label">
                @Html.LabelFor(m => m.Name)
            </div>
            <div class="col-sm-9">
                @Html.TextBoxFor(m => m.Name, null, new { @class = "form-control" })
                @Html.ValidationMessageFor(m => m.Name)
            </div>
        </div>

我一直在尝试创建一个 MvcHtmlString 自定义扩展,但它假定 @Html.LabelFor 命令是文本,这就是显示的内容。

编辑:谢谢乔和斯蒂芬!这就是我所缺少的。

这是我的代码块的最终答案

    static MvcHtmlString BaseFieldFor<TModel>(this HtmlHelper<TModel> helper, Expression<Func<TModel, string>> expression, MvcHtmlString innerHtml, string style = null) {
        var labelDiv = new TagBuilder("div");
        labelDiv.AddCssClass("col-sm-3 control-label");
        labelDiv.InnerHtml += helper.LabelFor(expression, new {
            htmlAttributes = new { @class = "form-control" }
        });
        var textDiv = new TagBuilder("div");
        textDiv.AddCssClass("col-md-9");
        textDiv.InnerHtml += innerHtml;
        textDiv.InnerHtml += helper.ValidationMessageFor(expression);
        var groupDiv = new TagBuilder("div");
        groupDiv.AddCssClass("form-group");
        groupDiv.InnerHtml += labelDiv;
        groupDiv.InnerHtml += textDiv;
        return new MvcHtmlString(groupDiv.ToString(TagRenderMode.Normal));
    }

和用法

    public static MvcHtmlString FieldFor<TModel>(this HtmlHelper<TModel> helper, Expression<Func<TModel, string>> expression, string style = null) {
        var innerHtml = helper.TextBoxFor(expression, null, new { @class = "form-control", style });
        return BaseFieldFor(helper, expression, innerHtml, style);
    }
    public static MvcHtmlString DropDownListFor<TModel>(this HtmlHelper<TModel> helper, Expression<Func<TModel, string>> expression, IEnumerable<SelectListItem> list, string style = null){
        var innerHtml = helper.DropDownListFor(expression, new SelectList(list, "Value", "Text"), new { @class = "form-control", style });
        return BaseFieldFor(helper, expression, innerHtml, style);
    }

现在我可以简单地使用它!

    <div class="panel-body form-horizontal">
        @Html.FieldFor(m => m.Name)
        @Html.FieldFor(m => m.Address1)
        @Html.FieldFor(m => m.Address2)
        @Html.FieldFor(m => m.City)
        @Html.DropDownListFor(m => m.State, AllowableValues.StateList, "max-width: 200px;")
        @Html.FieldFor(m => m.PostalCode, "max-width: 150px;")
        @Html.FieldFor(m => m.Phone, "max-width: 150px;")
    </div>

帮助程序需要使用内置的帮助程序方法来生成 html。例如

MvcHtmlString label = LabelExtensions.LabelFor(helper, expression});

请参阅此示例以创建输出类似 html(包括标签、文本框和验证消息)的帮助程序。

您无法以

尝试的方式调用 HTML 帮助程序。它所做的只是将其视为文本输出输出结果,如您已经看到的那样。

相反,您需要按如下方式引用 HTML 帮助程序:

string yourString = "Your string " + helper.LabelFor("text", "actionName");

最新更新