全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

asp.net core新特性之TagHelper标签助手

今天开始,我就来说说asp.net core的新特性,今天就说说TagHelper标签助手。虽然学习.net,最有帮助的就是microsoft的官方说明文档了,里面把一些使用说明都写的非常清楚,但奈何.net core放入文档微软还没来得及翻译,对于英文不好的人来说简直就是看的艰辛。所以今天就来学习学习这标签助手,和博客园大佬分享分享经验。

  想看Microsoft官方文档和Git项目的可以直接点击以下传送门~~

  asp.net core 官方文档

  asp.net core github项目

  说起TagHelper给我的印象,有点像asp.net form当中的服务器端控件,又有点像Angular或者Vue当中的“组件”的后端实现版本。用户可以将一组html标签集合转换为一个自定义标签,实现了html代码的复用。

  那么正文开始~~

  首先,我们需要安装一个vs2017插件:Razor Language Services。这个插件能在html中智能提示用户自定义的标签助手。

  https://marketplace.visualstudio.com/items?itemName=ms-madsk.RazorLanguageServices

创建一个asp.net core项目

使用微软定义的标签助手,在安装了插件后,使用标签助手的标签会进行高亮显示

上图中environment、link、a标签均使用了标签助手实现各自的功能

<a asp-area="" asp-controller="Home" asp-action="Index" class="navbar-brand">taghelpersample</a>

a标签中通过使用asp-controller,asp-action自定义属性来实现路由访问。

这时有人会说,我也可以使用@Html类来实现相同功能,为什么需要使用TagHelper?

@Html.ActionLink("taghelpersample", "Index", "Home",null, new { Class = "navbar-brand" })

确实,使用@Html帮助类我们能实现相同的功能,但是使用标签助手的方式不是更加符合html的标签语法吗,对于强迫症程序员简直就是福音~~。而且对于标签的原有属性的添加例如class,标签助手的使用也更加方便。

<!--标签助手版form-->
<form asp-controller="Home" asp-action="Index" class="form-horizontal" method="post">

</form>
<!--Html帮助类版form-->
@using (Html.BeginForm("Index", "Home", FormMethod.Post,, new { Class = "form-horizontal" }))
{

}


此外,标签助手的另外一个特色就是可以自定义,具体步骤如下:

(1)创建派生自TagHelper类的Class

 //类会默认转换为<text-collection></text-collection>
   public class TextCollectionTagHelper:TagHelper
 {
  public override void Process(TagHelperContext context, TagHelperOutput output)
  {
   base.Process(context, output);
  }
 }


(2)设置属性与基本类

public string Color { get; set; }

  public override void Process(TagHelperContext context, TagHelperOutput output)
  {
   output.TagName = "div";
   output.Attributes.Add("style", "color:" + Color);
   var text = "Hello,World";
   var h1 = new TagBuilder("h1");
   var h2 = new TagBuilder("h2");
   var h3 = new TagBuilder("h3");
   var h4 = new TagBuilder("h4");
   var h5 = new TagBuilder("h5");
   var h6 = new TagBuilder("h6");
   h1.InnerHtml.Append(text);
   h2.InnerHtml.Append(text);
   h3.InnerHtml.Append(text);
   h4.InnerHtml.Append(text);
   h5.InnerHtml.Append(text);
   h6.InnerHtml.Append(text);
   output.Content.AppendHtml(h1);
   output.Content.AppendHtml(h2);
   output.Content.AppendHtml(h3);
   output.Content.AppendHtml(h4);
   output.Content.AppendHtml(h5);
   output.Content.AppendHtml(h6);
  }


(3)在_ViewImports.cshtml导入类命名空间

@addTagHelper *,taghelpersample

(4)在cshtml中使用标签助手

<text-collection color="red"></text-collection>
<text-collection color="blue"></text-collection>
<text-collection color="#666"></text-collection>

(5)调试效果

OK,今天关于TagHelper就分享到这。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# asp.net  # core  # TagHelper  # asp.net core标签助手的高级用法TagHelper+Form  # asp.net core razor自定义taghelper的方法  # Razor TagHelper实现Markdown转HTML的方法  # Visual Studio 2017下ASP.NET CORE的TagHelper智能提示解决办法  # NET Core TagHelper实现分页标签  # 解读ASP.NET 5 & MVC6系列教程(13):TagHelper  # ASP.NET Core MVC中的标签助手(TagHelper)用法  # 自定义  # 文档  # 微软  # 来实现  # 转换为  # 大佬  # 的人  # 我也  # 我就  # 还没  # 又有  # 能在  # 英文  # 可以直接  # 会说  # 最有  # 可以使用  # 想看  # 另外一个  # 就来 


相关文章: 如何通过虚拟机搭建网站?详细步骤解析  如何快速查询域名建站关键信息?  赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?  洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?  建站之星如何实现网站加密操作?  头像制作网站在线制作软件,dw网页背景图像怎么设置?  建站之星在线客服如何快速接入解答?  武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?  黑客入侵网站服务器的常见手法有哪些?  宝塔建站无法访问?如何排查配置与端口问题?  如何在阿里云完成域名注册与建站?  如何通过PHP快速构建高效问答网站功能?  如何确认建站备案号应放置的具体位置?  c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】  安云自助建站系统如何快速提升SEO排名?  nginx修改上传文件大小限制的方法  专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何用VPS主机快速搭建个人网站?  为什么Go需要go mod文件_Go go mod文件作用说明  如何快速查询网址的建站时间与历史轨迹?  北京专业网站制作设计师招聘,北京白云观官方网站?  建站之星安全性能如何?防护体系能否抵御黑客入侵?  如何用PHP工具快速搭建高效网站?  如何在云主机快速搭建网站站点?  北京网站制作网页,网站升级改版需要多久?  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?  电脑免费海报制作网站推荐,招聘海报哪个网站多?  做企业网站制作流程,企业网站制作基本流程有哪些?  建站之星2.7模板:企业网站建设与h5定制设计专题  建站主机CVM配置优化、SEO策略与性能提升指南  内部网站制作流程,如何建立公司内部网站?  公众号网站制作网页,微信公众号怎么制作?  建站之星展会模版如何一键下载生成?  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  名字制作网站免费,所有小说网站的名字?  网站制作说明怎么写,简述网页设计的流程并说明原因?  免费制作小说封面的网站有哪些,怎么接网站批量的封面单?  西安大型网站制作公司,西安招聘网站最好的是哪个?  公司网站制作需要多少钱,找人做公司网站需要多少钱?  再谈Python中的字符串与字符编码(推荐)  怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?  如何通过NAT技术实现内网高效建站?  如何确保FTP站点访问权限与数据传输安全?  企业网站制作公司网页,推荐几家专业的天津网站制作公司?  小型网站制作HTML,*游戏网站怎么搭建?  如何自定义建站之星网站的导航菜单样式?  ppt制作免费网站有哪些,ppt模板免费下载网站?  实例解析Array和String方法  香港服务器部署网站为何提示未备案? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。