【TypeScript】枚举类型

这篇具有很好参考价值的文章主要介绍了【TypeScript】枚举类型。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

在 TypeScript 中,枚举(Enum)是一种用于定义命名常量集合的数据类型。枚举使代码更加可读和可维护,因为它们为一组具有语义的值提供了命名。

以下是 TypeScript 中枚举的基本用法和特点:

// 声明一个枚举
enum Direction {
  North,
  South,
  East,
  West
}

// 使用枚举值
console.log(Direction.North); // 输出:0

// 修改枚举值
console.log(Direction.East); // 输出:2

枚举的特点:

  1. 枚举中的每个成员都有一个关联的数字值,称为枚举值。默认情况下,从 0 开始,逐一递增。

  2. 枚举值可以通过成员的名字或者成员的值来访问。

  3. 枚举可以具有字符串、数字、或者混合类型的值。

  4. 枚举成员的值可以手动指定,从而覆盖默认的递增行为。

enum Status {
  Pending = 21,
  Approved = 'APPROVED',
}

console.log(Status.Pending); // 输出:21
console.log(Status.Approved); // 输出:APPROVED
  1. 枚举可以反向映射,即可以通过值找到相应的成员名。
console.log(Status['PENDING']); // 输出:PENDING
  1. 接口枚举
enum Types {
  a,
  b
}
interface A {
  red: Types.a,
}
// 应用场景:把对象属性定义为枚举对象,属性就被限定为只能使用枚举范围内的成员
let obj: A = {
  red: Types.a
}
  1. const 枚举

index.ts

enum Types {
  success,
  fail
}
let code:number = 0
if(code === Types.success){
  console.log('success')
}else{
  console.log('fail')
}

编译为对象:

index.js

var Types;
(function (Types) {
    Types[Types["success"] = 0] = "success";
    Types[Types["fail"] = 1] = "fail";
})(Types || (Types = {}));
var code = 0;
if (code === Types.success) {
    console.log('success');
}
else {
    console.log('fail');
}

而如果用 const 修饰:

index.ts

const enum Types {
  success,
  fail
}
let code:number = 0
if(code === Types.success){
  console.log('success')
}else{
  console.log('fail')
}

编译为常量:

index.js

var code = 0;
if (code === 0 /* Types.success */) {
    console.log('success');
}
else {
    console.log('fail');
}

  1. 反向映射

支持数字,不支持字符串文章来源地址https://www.toymoban.com/news/detail-665573.html

enum Types {
  success = 1,
  fail = 2
}
console.log(Types.success); // 1
// 以下反向映射不可以用 const 修饰 Types
console.log(Types[1]); // success

到了这里,关于【TypeScript】枚举类型的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 前端TypeScript学习day03-TS高级类型

    (创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹)            目录 TypeScript 高级类型 class 类 class继承  extends implements  类成员可见性  public  protected  private   readonly 兼容性 类型兼容性 接口兼容性  函数兼容性  TypeScri

    2024年02月08日
    浏览(27)
  • 前端TypeScript学习day02-TS常用类型

    (创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹) 目录 TypeScript 常用类型 接口  元组  类型推论 类型断言 字面量类型 枚举 any 类型 typeof  当一个对象类型被多次使用时,一般会使用接口(interface)来描述对象的类型,达到

    2024年02月08日
    浏览(44)
  • 前端TypeScript学习day04-交叉类型与泛型

    (创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹)            目录 交叉类型 泛型 创建泛型函数 调用泛型函数: 简化调用泛型函数: 泛型约束  指定更加具体的类型 添加约束  泛型接口  泛型类 泛型工具类型  Partial 

    2024年02月08日
    浏览(34)
  • 前端TypeScript学习day05-索引签名、映射与类型声明文件

    (创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹)              目录 索引签名类型  映射类型 索引查询(访问)类型 基本使用  同时查询多个索引的类型  TypeScript 类型声明文件  概述 TS 的两种文件类型  类型声明文件的

    2024年02月08日
    浏览(37)
  • 前端TypeScript学习day01-TS介绍与TS部分常用类型

    (创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹) 目录 TypeScript 介绍 TypeScript 是什么 TypeScript 为什么要为 JS 添加类型支持?  TypeScript 相比 JS 的优势  TypeScript 初体验  安装编译 TS 的工具包 编译并运行 TS 代码 简化运行 TS

    2024年02月08日
    浏览(27)
  • 前端经典面试题 | 吊打面试官系列 之 说说你对TypeScript 和 JavaScript的理解

    🖥️ 前端经典面试题 专栏:吊打面试官系列 之 说说你对TypeScript 和 JavaScript的理解 🧑‍💼 个人简介:一个不甘平庸的平凡人🍬 ✨ 个人主页:CoderHing的个人主页 🍀 格言: ☀️ 路漫漫其修远兮,吾将上下而求索☀️ 👉 你的一键三连是我更新的最大动力❤️ 目录 一、回答

    2024年01月17日
    浏览(37)
  • typeScript(枚举篇)

    使用枚举我们可以定义一些带名字的常量。 使用枚举可以清晰地表达意图或创建一组有区别的用例。 TypeScript支持数字的和基于字符串的枚举。 首先我们看看数字枚举,如果你使用过其它编程语言应该会很熟悉。 如上,我们定义了一个数字枚举,  Up 使用初始化为  1 。 其

    2024年02月09日
    浏览(24)
  • TypeScript【enum 枚举】

    导语 在 TypeScript 中,新增了很多具有特性的一些数据类型处理方法, enum 【枚举】 就是其中,很具有代表性的一种,所以本章节就来聊聊 在 TypeScript 中如何去运用 enum 【枚举】 。 枚举的 概念 : 枚举(Enum)类型 用于取值被限定在一定范围内的场景 ,比如一周只能有七天

    2024年02月14日
    浏览(28)
  • TypeScript枚举:方便的常量定义方式

    在 TypeScript 中,枚举是一个非常重要的特性,它提供了一种方便的常量定义方式。在本文中,我们将详细探讨 TypeScript 枚举的用法和优势。 枚举是指 一组命名的常量 ,这些常量称为 枚举成员 。枚举可以在 TypeScript 中以类似于 C# 和 Java 的方式来定义,它们在 JavaScript 中被编

    2024年02月11日
    浏览(30)
  • 详细版易学版TypeScript - 元组 枚举

    数组:合并了相同类型的对象 元组(Tuple):合并了不同类型的对象 1、前端为什么要使用枚举 去魔数化:一旦有个数值改动,不用再全局替换匹配 语义化:可以直观通过值推导出含义,例如,通过 STATUS.SUCCESS 就可以大概猜出含义 定义一体化:枚举值和枚举描述写在了一起,

    2024年02月03日
    浏览(24)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包