.net工具類 獲取枚舉類型的描述

来源:https://www.cnblogs.com/hucheng/archive/2018/11/02/9898285.html
-Advertisement-
Play Games

一般情況我們會用枚舉類型來存儲一些狀態信息,而這些信息有時候需要在前端展示,所以需要展示中文註釋描述。 為了方便獲取這些信息,就封裝了一個枚舉擴展類。 上面代碼中的 ComboboxItemDto 類是來自 Abp 源碼,它主要用於提供前端下拉框的數據源。 好了,下麵來舉個慄子,這是一個訂單枚舉類 ...


一般情況我們會用枚舉類型來存儲一些狀態信息,而這些信息有時候需要在前端展示,所以需要展示中文註釋描述。

為了方便獲取這些信息,就封裝了一個枚舉擴展類。

    /// <summary>
    /// 枚舉擴展類
    /// </summary>
    public static class EnumExtension
    {
        /// <summary>
        /// 獲取枚舉的描述,需要DescriptionAttribute屬性
        /// </summary>
        /// <param name="e"></param>
        /// <returns></returns>
        public static string GetDescription(this Enum e)
        {
            //獲取枚舉的Type類型對象
            var type = e.GetType();
            //獲取枚舉的所有欄位
            var fields = type.GetFields();

            //遍歷所有枚舉的所有欄位
            foreach (var field in fields)
            {
                if (field.Name != e.ToString())
                {
                    continue;
                }
                //第二個參數true表示查找EnumDisplayNameAttribute的繼承鏈

                if (field.IsDefined(typeof(DescriptionAttribute), true))
                {
                    var attr = field.GetCustomAttribute(typeof(DescriptionAttribute), false) as DescriptionAttribute;
                    if (attr != null)
                    {
                        return attr.Description;
                    }
                }
            }

            //如果沒有找到自定義屬性,直接返回屬性項的名稱
            return e.ToString();
        }

        /// <summary>
        /// 根據枚舉獲取下拉框列表
        /// </summary>
        /// <param name="en"></param>
        /// <returns></returns>
        public static List<ComboboxItemDto> GetSelectList(this Enum en)
        {
            var list = new List<ComboboxItemDto>();

            foreach (var e in Enum.GetValues(en.GetType()))
            {
                list.Add(new ComboboxItemDto() { DisplayText = GetDescription(e as Enum), Value = ((int)e).ToString(), IsSelected = e == en });
            }

            return list;
        }

        /// <summary>
        /// 根據枚舉獲取下拉框列表
        /// </summary>
        /// <param name="type">枚舉類型</param>
        /// <returns></returns>
        public static List<ComboboxItemDto> GetSelectList(this Type type)
        {
            var list = new List<ComboboxItemDto>();

            foreach (var e in Enum.GetValues(type))
            {
                list.Add(new ComboboxItemDto() { DisplayText = GetDescription(e as Enum), Value = ((int)e).ToString() });
            }

            return list;
        }
    }

上面代碼中的 ComboboxItemDto 類是來自 Abp 源碼,它主要用於提供前端下拉框的數據源。

    //
    // 摘要:
    //     This DTO can be used as a simple item for a combobox/list.
    public class ComboboxItemDto
    {
        //
        // 摘要:
        //     Creates a new Abp.Application.Services.Dto.ComboboxItemDto.
        public ComboboxItemDto();
        //
        // 摘要:
        //     Creates a new Abp.Application.Services.Dto.ComboboxItemDto.
        //
        // 參數:
        //   value:
        //     Value of the item
        //
        //   displayText:
        //     Display text of the item
        public ComboboxItemDto(string value, string displayText);

        //
        // 摘要:
        //     Value of the item.
        public string Value { get; set; }
        //
        // 摘要:
        //     Display text of the item.
        public string DisplayText { get; set; }
        //
        // 摘要:
        //     Is selected?
        public bool IsSelected { get; set; }
    }

 

好了,下麵來舉個慄子,這是一個訂單枚舉類

    /// <summary>
    /// 商品訂單狀態
    /// </summary>
    public enum CommodityOrderState
    {
        /// <summary>
        /// 待付款
        /// </summary>
        [Description("待付款")]
        PendingPay,
        /// <summary>
        /// 待發貨
        /// </summary>
        [Description("待發貨")]
        PendingShip,
        /// <summary>
        /// 待收貨
        /// </summary>
        [Description("待收貨")]
        PendingReceipt,
        /// <summary>
        /// 待評價
        /// </summary>
        [Description("待評價")]
        PendingEvaluation,
        /// <summary>
        /// 已評價
        /// </summary>
        [Description("已評價")]
        Evaluated,
        /// <summary>
        /// 已退款
        /// </summary>
        [Description("已退款")]
        Refunded = 100
    }

這是一個訂單DTO,一般會存在訂單狀態欄位,就像這樣。

        /// <summary>
        /// 訂單狀態(這個欄位會通過AutoMapper自動映射)
        /// </summary>
        public CommodityOrderState State { get; set; }
        /// <summary>
        /// 訂單狀態描述
        /// </summary>
        public string StateDesc => State.GetDescription();

好了,這樣前端就能拿到訂單狀態描述信息了,是不是很方便。

 


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

-Advertisement-
Play Games
更多相關文章
  • 內置函數: continue... 傳送門 ...
  • 1、作用域相關 locals() 功能:返回當作用域中的名字 globals() 功能:返回全局作用域中的名字 2、迭代器/生成器相關 range() 功能:生成數據 iter() 功能:獲取迭代器,內部實際使用的是__iter__()方法來獲取迭代器 next() 功能:迭代器向下執行一次,內部實 ...
  • 介紹 在 C# 程式中嵌入 IronPython 得到了很好的支持。在本教程中,我們將展示如何完成這個項目。 首先,我們將展示兩個非常基本的例子,說明如何執行一個不導入任何模塊的非常簡單的腳本。然後,再展示如何執行使用模塊的腳本。 在 C 中執行 Python 第一個例子 我們來創建一個執行Pyth ...
  • 剛開始接觸 python 的時候,對 python 中的 wargs (可變參數) 和 kwargs (關鍵字參數)的理解不是很透徹,看了一下 《Explore Python》一書,裡面對這一部分的描述相對淺顯易懂, 這裡依據個人理解進行相關總結。 可變參數( args) 對於可變參數可以聯想到 C ...
  • #[每一個元素或者是和元素相關的操作 for 元素 in 可迭代數據類型] #遍歷之後挨個處理 #[滿足條件的元素相關的操作 for 元素 in 可迭代數據類型 if 元素相關的條件] #篩選功能 # #30以內所有能被3整除的數 ret = [i for i in range(30) if i%3... ...
  • 介面用法簡介 介面(interface)是一種類型,用來定義行為(方法)。 但這些行為不會在介面上直接實現,而是需要用戶自定義的方法來實現。所以,在上面的Namer介面類型中的方法 都是沒有實際方法體的,僅僅只是在介面Namer中存放這些方法的簽名( )。 當用戶自定義的類型實現了介面上定義的這些方 ...
  • 之前有總結髮表過《近期開發項目中用到的編碼小技巧彙總說明》,雖沒有涉及什麼高大上的東西,但都是一些很實用的平時大家可能用到的知識,今天繼續分享一些小技巧,歡迎大家瞭解,不足之處,可以直接評論留言謝謝! 接上篇序號 6.解決當同一個類在不同的項目中(命名空間不同,但類的定義完全相同的情況)使用Bina ...
  • Server 端示例代碼: Client 端示例代碼: It supports: WebSocket Client and Server RFC 6455 Per message Compression extension Secure Connection HTTP Authentication ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...