解讀 TypeScript 枚舉Enum

TypeScript 枚舉通過命名常量、類型安全和結構化組織,顯著提升代碼質量。使用時需根據場景選擇合適的類型(數字、字符串或常量枚舉),并權衡性能與動態訪問需求。掌握其特性和使用的場景,能在復雜項目中有效提升代碼的可維護性和健壯性。接下來我會通過案例,深入解讀Enum。

一、枚舉的核心作用

  1. 替代魔法值 用有意義的名稱取代硬編碼數字或字符串,減少代碼歧義。

    enum StatusCode { Success = 200, NotFound = 404 }
    if (response.status === StatusCode.Success) { ... } // 比直接判斷200更清晰
  2. 類型安全 限制變量只能使用枚舉成員,編譯器會在賦值或比較時檢查類型。

    enum Direction { Up, Down }
    let dir: Direction = Direction.Up; // 正確
    dir = 3; // 錯誤:不能將數字直接賦值給枚舉類型
  3. 組織相關常量 將邏輯關聯的常量歸類,便于維護和擴展。

    enum LogLevel { Info, Warn, Error }

二、枚舉的類型與語法

1.?數字枚舉(默認)

  • 成員默認從?0?開始自增,也可手動賦值。
  • 支持反向映射:通過值獲取名稱(僅數字枚舉)。
    enum Direction {Up = 1,     // 顯式賦值Down,       // 自動遞增為2Left = 4,Right,      // 自動遞增為5
    }
    console.log(Direction.Down);    // 輸出: 2
    console.log(Direction[2]);      // 輸出: "Down"(反向映射)

2.?字符串枚舉

  • 成員必須顯式初始化字符串值。
  • 無反方向映射,適用于需明確語義的場景。
    enum LogLevel {Info = "INFO",Warn = "WARN",Error = "ERROR"
    }
    console.log(LogLevel.Info); // 輸出: "INFO"

3.?常量枚舉(const enum

  • 編譯時被完全內聯,無運行時對象
  • 提升性能,但無法反射或動態訪問。
    const enum Size { Small, Medium }
    let size = Size.Small; // 編譯后:let size = 0;

4.?異構枚舉(不推薦)

  • 混合數字和字符串成員,易引發混亂。
    enum BooleanLikeEnum {No = 0,Yes = "YES",
    }

5. 同名枚舉合并?

多個同名的 Enum 結構會自動合并。

enum Foo {A,
}
enum Foo {B = 1,
}
enum Foo {C = 2,
}
// 等同于
enum Foo {A,B = 1,C = 2
}

三、枚舉的高級特性

1.?計算成員與常量成員

  • 常量成員:值在編譯時確定(字面量、其他常量成員引用)。
  • 計算成員:值在運行時計算(需顯式初始化后續成員)。
    enum FileAccess {None,                   // 常量成員 0Read = 1 << 1,          // 計算成員 2Write = 1 << 2,         // 計算成員 4ReadWrite = Read | Write, // 計算成員 6// 后續成員必須顯式初始化Execute = 8
    }

2.?枚舉作為類型

  • 限制變量或參數只能為枚舉成員值,這是枚舉的一個缺點。
    enum UserRole { Admin, Guest }
    function setRole(role: UserRole) { ... }
    setRole(UserRole.Admin); // 正確
    setRole(2); // 錯誤:類型不符

四、枚舉的優缺點對比

優點缺點
提升代碼可讀性編譯后生成額外代碼(非 const enum)
編譯時類型檢查字符串枚舉不支持反向映射
支持反向映射(數字枚舉)異構枚舉易導致邏輯混亂
便于統一管理常量動態訪問可能繞過類型檢查(數字枚舉)

五、使用場景

  1. 優先使用字符串枚舉 提高代碼自描述性,避免數字枚舉的隱式歧義。

  2. 性能敏感場景用 const enum 減少生成代碼量,但需確保無需動態訪問枚舉。

  3. 替代方案考量

    • 聯合類型:適用于簡單且無需反向映射的場景。
      type LogLevel = 'INFO' | 'WARN' | 'ERROR';
    • 對象常量:需手動凍結對象防止修改,無類型約束。
      const LogLevel = { Info: 'INFO' } as const;

?引用一個例子:Enum 結構比較適合的場景是,成員的值不重要,名字更重要,從而增加代碼的可讀性和可維護性。

enum Operator {ADD,DIV,MUL,SUB
}
function compute(op:Operator,a:number,b:number
) {switch (op) {case Operator.ADD:return a + b;case Operator.DIV:return a / b;case Operator.MUL:return a * b;case Operator.SUB:return a - b;default:throw new Error('wrong operator');}
}
compute(Operator.ADD, 1, 3) // 4

?上面示例中,Enum 結構Operator的四個成員表示四則運算“加減乘除”。代碼根本不需要用到這四個成員的值,只用成員名就夠了。

六、示例對比

枚舉 vs 聯合類型

枚舉方案

enum Theme { Dark = 'dark', Light = 'light' }
function setTheme(theme: Theme) { ... }
setTheme(Theme.Dark);

聯合類型方案

type Theme = 'dark' | 'light';
function setTheme(theme: Theme) { ... }
setTheme('dark');

對比

  • 枚舉集中管理常量,修改時只需調整枚舉定義。
  • 聯合類型無需生成額外代碼,適合簡單場景。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/906025.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/906025.shtml
英文地址,請注明出處:http://en.pswp.cn/news/906025.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

MODBUS RTU通信協議詳解與調試指南

一、MODBUS RTU簡介 MODBUS RTU&#xff08;Remote Terminal Unit&#xff09;是一種基于串行通信&#xff08;RS-485/RS-232&#xff09;的工業標準協議&#xff0c;采用二進制數據格式&#xff0c;具有高效、可靠的特點&#xff0c;廣泛應用于PLC、傳感器、變頻器等工業設備…

TCP/UDP協議原理和區別 筆記

從簡單到難吧 區別就是TCP一般用于安全穩定的需求&#xff0c;UDP一般用于不那么需要完全數據的需求&#xff0c;比如說直播&#xff0c;視頻等。 再然后就是TPC性能慢于UDP。 再然后我們看TCP的原理&#xff08;三次握手&#xff0c;數據傳輸&#xff0c;四次揮手&#xff0…

Jackson使用詳解

JSON Jackson是java提供處理json數據序列化和反序列的工具類&#xff0c;在使用Jackson處理json前&#xff0c;我們得先掌握json。 JSON數據類型 類型示例說明字符串&#xff08;String&#xff09;"hello"雙引號包裹&#xff0c;支持轉義字符&#xff08;如 \n&a…

C語言| 指針變量的定義

C語言| 指針的優點-CSDN博客 * 表示“指向”&#xff0c;為了說明指針變量和它所指向的變量之間的聯系。 int * i&#xff1b;//表示指針變量i里面存放的地址&#xff0c;所指向的存儲單元里的【數據】。 【指針變量的定義】 C語言規定所有變量&#xff0c;在使用前必須先定…

Java 快速轉 C# 教程

以下是一個針對 Java 開發者快速轉向 C# 的簡明教程&#xff0c;重點對比 Java 與 C# 的異同&#xff0c;幫助你快速上手。 項目結構&#xff1a; .sln &#xff1a;解決方案文件&#xff0c;管理多個項目之間的依賴關系。.csproj &#xff1a;項目文件&#xff0c;定義目標框…

EasyExcel詳解

文章目錄 一、easyExcel1.什么是easyExcel2.easyExcel示例demo3.easyExcel read的底層邏輯~~4.easyExcel write的底層邏輯~~ 二、FastExcel1.為什么更換為fastExcel2.fastExcel新功能 一、easyExcel 1.什么是easyExcel 內容摘自官方&#xff1a;Java解析、生成Excel比較有名的…

jvm安全點(三)openjdk17 c++源碼垃圾回收之安全點結束,喚醒線程

1. VMThread::inner_execute() - 觸發安全點?? cpp 復制 void VMThread::inner_execute(VM_Operation* op) { if (op->evaluate_at_safepoint()) { SafepointSynchronize::begin(); // 進入安全點&#xff0c;阻塞所有線程 // ...執行GC等操作... SafepointSynchronize::…

102. 二叉樹的層序遍歷遞歸法:深度優先搜索的巧妙應用

二叉樹的層序遍歷是一種經典的遍歷方式&#xff0c;它要求按層級逐層訪問二叉樹的節點。通常我們會使用隊列來實現層序遍歷&#xff0c;但遞歸法也是一種可行且有趣的思路。本文將深入探討遞歸法解決二叉樹層序遍歷的核心難點&#xff0c;并結合代碼和模擬過程進行詳細講解。 …

首個窗口級無人機配送VLN系統!中科院LogisticsVLN:基于MLLM實現精準投遞

導讀 隨著智能物流需求日益增長&#xff0c;特別是“最后一公里”配送場景的精細化&#xff0c;傳統地面機器人逐漸暴露出適應性差、精度不足等瓶頸。為此&#xff0c;本文提出了LogisticsVLN系統——一個基于多模態大語言模型的無人機視覺語言導航框架&#xff0c;專為窗戶級別…

WPF Datagrid 數據加載和性能

這篇文章并非討論 WPF Datagrid 的性能數據&#xff0c;而只是簡單介紹一下為了使其性能良好&#xff0c;你需要注意哪些方面。我不太想使用性能分析器來展示實際數據&#xff0c;而是盡可能地使用了 Stopwatch 類。這篇文章不會深入探討處理海量數據的技術&#xff0c;例如分頁…

matlab求矩陣的逆、行列式、秩、轉置

inv - 計算矩陣的逆 用途&#xff1a;計算一個可逆矩陣的逆矩陣。 D [1, 2; 3, 4]; % 定義一個2x2矩陣 D_inv inv(D); % 計算矩陣D的逆 disp(D_inv);det - 計算矩陣的行列式 用途&#xff1a;計算方陣的行列式。 E [1, 2; 3, 4]; determinant det(E); % 計算行列式 disp…

ridecore流水線解讀

文章目錄 流水線stage分屬前后端PCpipelineIFIDDPDP 與 SW 中間沒有latchSWCOM 源碼地址 流水線stage分屬前后端 IF -> ID -> DP -> SW -> EX -> COM分類階段說明前端IF指令獲取階段。PC 使用分支預測器&#xff0c;訪問指令存儲器。典型前端操作。前端ID解碼并…

【SpringBoot】關于MP使用中配置了數據庫表前綴的問題

problem 使用MP時&#xff0c;在application.yml配置文件中配置了MP匹配數據庫表中的表名時的前綴作了規定&#xff0c;如下&#xff1a; 那么當我運行時報錯了錯誤&#xff0c;報錯信息如下&#xff1a; 因為我數據庫表的書類表名是book&#xff0c;MP在匹配時使用了表名前…

印度Rummy游戲支付通道申請策略:技巧類游戲的合規與創新

本文為印度支付申請科普文&#xff0c;自去年開始&#xff0c;印度Rummy類游戲申請印度支付都需要擁有AIGF的會員及產品證書。 如需要rummy可以通過AIGF審核的源。碼&#xff0c;或咨詢AIGF的相關內容&#xff0c;可以聯。系老妙。 印度作為全球棋牌類游戲增長最快的市場之一&…

日志與策略模式

什么是設計模式 IT?業 ,為了讓 菜雞們不太拖?佬的后腿, 于是?佬們針對?些經典的常?的場景, 給定了?些對應的解決?案, 這個就是 設計模式 日志認識 計算機中的?志是記錄系統和軟件運?中發?事件的?件&#xff0c;主要作?是監控運?狀態、記錄異常信 息&#xff…

解鎖Ubuntu高效部署!自動安裝配置文件YAML全解析

我們之前介紹了兩種Ubuntu系統的安裝方式&#xff0c;分別對應桌面版&#xff08;準備搞OpenStack了&#xff0c;先裝一臺最新的Ubuntu 23.10&#xff09;和服務器版&#xff08;Ubuntu 22.04 LTS服務器版本安裝演示&#xff09;。但對于有些用戶&#xff0c;因為技術問題&…

關系代數和關系數據庫語言(SQL)

閱讀提示&#xff1a;本篇文章較長&#xff0c;建議從目錄上選取想看的內容。代碼上的話&#xff0c;我習慣用小寫&#xff0c;如果看不習慣建議跳過。有問題歡迎討論&#xff01;&#xff01;&#xff01; 一、基礎概念 1.1數據庫的概念 數據庫(Database)是按照數據結構來組…

EXO 可以將 Mac M4 和 Mac Air 連接起來,并通過 Ollama 運行 DeepSeek 模型

EXO 可以將 Mac M4 和 Mac Air 連接起來&#xff0c;并通過 Ollama 運行 DeepSeek 模型。以下是具體實現方法&#xff1a; 1. EXO 的分布式計算能力 EXO 是一個支持 分布式 AI 計算 的開源框架&#xff0c;能夠將多臺 Mac 設備&#xff08;如 M4 和 Mac Air&#xff09;組合成…

區塊鏈基本理解

文章目錄 前言一、什么是分布式賬本(DLT)二、什么是P2P網絡?二、共識算法三、密碼算法前言 區塊鏈是由一個一個數據塊組成的鏈條,按照時間順序將數據塊逐一鏈接,通過哈希指針鏈接,所有的數據塊共同維護一份分布式賬本(DLT),每個節點(可以理解為一個玩家,一臺計算機)都擁…

Node.js中的洋蔥模型

文章目錄 前言 前言 Node.js中的洋蔥模型是一種中間件執行機制&#xff0c;主要用于處理HTTP請求和響應的流程控制。該模型通過層層包裹的中間件結構&#xff0c;實現請求從外到內穿透、響應從內向外返回的順序執行。以下從核心概念、實現原理、框架差異及實際應用等方面解析&…