加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

使用ASP.NET MVC 3助手的标题属性的渲染跨度标签

发布时间:2020-12-16 00:31:18 所属栏目:asp.Net 来源:网络整理
导读:可以向输入标签添加HTML标题属性,如下所示: @Html.TextBoxFor(model = model.Name,new { title = "Customer name" }) 静态文本有类似的帮助吗?使用@ Html.DisplayFor(model = model.Name)我可以从模型属性渲染文本。如何添加HTML属性,以便我得到如下渲染
可以向输入标签添加HTML标题属性,如下所示:
@Html.TextBoxFor(model => model.Name,new { title = "Customer name" })

静态文本有类似的帮助吗?使用@ Html.DisplayFor(model => model.Name)我可以从模型属性渲染文本。如何添加HTML属性,以便我得到如下渲染的跨标签:

<span title="Customer name">ABC</span>

解决方法

自定义html帮助器可能是最整洁的解决方案。
public static MvcHtmlString SpanFor<TModel,TProperty>(this HtmlHelper<TModel> helper,Expression<Func<TModel,TProperty>> expression,object htmlAttributes = null)
{
    var valueGetter = expression.Compile();
    var value = valueGetter(helper.ViewData.Model);

    var span = new TagBuilder("span");
    span.MergeAttributes(new RouteValueDictionary(htmlAttributes));
    if (value != null)
    {
        span.SetInnerText(value.ToString());
    }

    return MvcHtmlString.Create(span.ToString());
}

=>

@Html.SpanFor(model => model.Name,new { title = "Customer name" })

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读