asp.net core razor自定義taghelper

来源:https://www.cnblogs.com/yyfh/archive/2019/09/18/11541067.html
-Advertisement-
Play Games

又一個新的名詞(taghelper),通過taghelper是可以操作html標簽、條件輸出、更是自由添加內外元素。當然也內置了挺多的asp 開頭的taghelper。 下麵文章中也簡單的帶大家實現一個taghelper; 創建自定義html元素 創建一個類ButtonTagHelper tagNa ...


又一個新的名詞(taghelper),通過taghelper是可以操作html標簽、條件輸出、更是自由添加內外元素。當然也內置了挺多的asp-開頭的taghelper。

下麵文章中也簡單的帶大家實現一個taghelper;

創建自定義html元素

創建一個類ButtonTagHelper

tagName為標簽名稱,下麵創建一個button標簽

using Microsoft.AspNetCore.Razor.TagHelpers;

namespace Ctrl.Core.Tag.Controls.Button
{
    [HtmlTargetElement("test-button")]
    public class ButtonTagHelper:TagHelper
    {
        public override void Process(TagHelperContext context, TagHelperOutput output)
        {
            output.TagName = "button";
            base.Process(context, output);
        }
    }
}

註冊taghelper

創建完後可沒法執行使用哦,在.cshtml通過某個標簽比如form標簽輸入asp-,下麵立刻就出現了一個列表 asp-.... ,這些是怎麼做到的呢?因為在_ViewImports在我們創建項目工程時,已經提前引入了taghelper預設引入的是微軟已經為我們寫好的taghelper類庫Microsoft.AspNetCore.Mvc.TagHelpers;

我們自定義的話也需要按照這個方式引入自定義的taghelper,下麵我自己創建了一個類庫名字為"Ctrl.Core.Tag",我這個類庫下麵要存放所有的taghelper 我直接引入命名空間

@addTagHelper *,Ctrl.Core.Tag

如果想引入特定的taghelper如下

@addTagHelper 你的TagHelper , 命名空間

然後我們測試一下是否可用了,先生成一下項目,然後找個cshtml視圖,輸入剛纔的首碼test會出來剛纔定義的標簽

添加上並運行項目查看剛纔創建的button標簽是否存在

添加自定義屬性

上面需求是滿足不了我們日常需求的,下麵我們再定義一個元素屬性

 output.Attributes.SetAttribute("class", "btn btn-primary");

然後再打開頁面看效果就會看到class元素已經給加上了.

using Microsoft.AspNetCore.Razor.TagHelpers;

namespace Ctrl.Core.Tag.Controls.Button
{
    [HtmlTargetElement("test-button")]
    public class ButtonTagHelper:TagHelper
    {
        public override void Process(TagHelperContext context, TagHelperOutput output)
        {
            output.TagName = "button";
            output.Attributes.SetAttribute("class", "btn btn-primary");
            base.Process(context, output);
        }
    }
}

通過vs感知匹配按鈕類型

上面能滿足我們自定義標簽了,但是可能使用起來有局限性,下麵我給大家提供一個場景思路,後面大家可以自己進行擴展.

我創建一個枚舉類為 CtrlButtonType

namespace Ctrl.Core.Tag.Controls.Button
{
    /// <summary>
    ///     按鈕類型
    /// </summary>
    public enum CtrlButtonType
    {
        /// <summary>
        ///  預設樣式
        /// </summary>
        Default,
        /// <summary>
        ///     首選項
        /// </summary>
        Primary,
        /// <summary>
        ///      成功
        /// </summary>
        Success,
        /// <summary>
        ///  一般信息
        /// </summary>
        Info,
        /// <summary>
        ///  警告
        /// </summary>
        Warning,
        /// <summary>
        ///  危險
        /// </summary>
        Danger
    }
}

在buttonTagHelper類中增加一個屬性

public CtrlButtonType ButtonType  { get; set; }

到cshtml中添加剛纔那個頁面的屬性,會發現有提示,以及可以看到剛纔枚舉中定義的.這樣通過vs感知以及通過類型指定我們剛纔按鈕的類型是不是很方面了.


namespace Ctrl.Core.Tag.Controls.Button
{
    [HtmlTargetElement("test-button")]
    public class ButtonTagHelper:TagHelper
    {
        public CtrlButtonType ButtonType  { get; set; }
        public override void Process(TagHelperContext context, TagHelperOutput output)
        {
            output.TagName = "button";
            output.Attributes.SetAttribute("class", "btn btn-"+ButtonType.ToString().ToLower());
            base.Process(context, output);
        }
    }
}
 <test-button button-type="Success"></test-button>


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一個簡單的批量二維碼生成器 最近需要將大量的字元串生成二維碼, 網上找了很多網站和應用都不是很理想,乾脆自己做了吧! github 上找了下找到QrCode 開源項目 QrCode 開源類庫 安裝qrcode非常簡單, "參考這裡" 引用 dll 核心邏輯 加個界面 功能完成了,如果要給其他人用還需 ...
  • 前言 面試以及考試過程中必會出現一道排序演算法面試題,為了加深對排序演算法的理解,在此我對各種排序演算法做個總結歸納。 1、冒泡排序演算法(BubbleSort) 1.1 演算法描述 (1)比較相鄰的元素。如果第一個比第二個大,就交換他們兩個。 (2)對每一對相鄰元素做同樣的工作,從開始第一對到結尾的最後一對 ...
  • 前提 入行已經7,8年了,一直想做一套漂亮點的自定義控制項,於是就有了本系列文章。 GitHub:https://github.com/kwwwvagaa/NetWinformControl 碼雲:https://gitee.com/kwwwvagaa/net_winform_custom_contr ...
  • <Style x:Key="workButtonStyle" TargetType="{x:Type Button}"> <Style.Triggers> <Trigger Property="IsMouseOver" Value="False"> <Setter Property="FontSiz... ...
  • C#上手練習2(FOR語句) ...
  • 1.索引器的索引值類型不限定為整數 2.索引器允許重載 3.索引器不是一個變數 4.索引器以函數簽名方式this標識,而屬性採用名稱來標識,名稱可以任意 5.索引器不能使用static來進行聲明,屬性可以。索引器永遠屬於實例成員,因此不能聲明為static。 ...
  • 1、列印字元串。 2、調用簡單方法,方法里有if語句、Swich語句。 ...
  • lambda演變歷史 .NetFramework1.0 1.1下,lambda表達式是這樣去寫的,首先聲明一個無參無返回值delegate委托,再聲明一個無參無返回值的方法,把這個方法當做參數一樣傳遞給委托 你也可以聲明一個有參數和有返回值的委托,就像聲明方法一樣: .NetFramework2.0 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...