首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >包含Razor语句的MvcHtmlString

包含Razor语句的MvcHtmlString
EN

Stack Overflow用户
提问于 2014-11-20 17:52:15
回答 2查看 2.9K关注 0票数 1

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

代码语言:javascript
复制
        <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命令是文本,这就是显示的内容。

编辑:谢谢乔和斯蒂芬!那就是我错过的。

下面是我的代码块的最终答案

代码语言:javascript
复制
    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));
    }

并供使用

代码语言:javascript
复制
    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);
    }

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

代码语言:javascript
复制
    <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>
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-11-20 22:35:14

您的助手需要使用内置的助手方法来生成html。例如

代码语言:javascript
复制
MvcHtmlString label = LabelExtensions.LabelFor(helper, expression});

Refer this example,用于创建一个输出类似html的助手,包括标签、文本框和验证消息。

票数 3
EN

Stack Overflow用户

发布于 2014-11-20 22:14:06

您无法以尝试这样做的方式调用HTML帮助程序。它所要做的就是把它当作文本输出,正如您已经看到的结果。

相反,您需要引用HTML助手,如下所示:

代码语言:javascript
复制
string yourString = "Your string " + helper.LabelFor("text", "actionName");
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27046267

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档