• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

TypeScript--枚举

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

常数枚举

使用枚举我们可以定义一些有名字的数字常量。 枚举通过 enum 关键字来定义

enum Status {  // 定义了一个枚举 Staus,里面有三个枚举成员
  Uploading,
  Success,
  Faild
}

// 枚举的取值有下面两种方式取值
console.log(Status.Uploading)  // 结果为 0
console.log(Status['Success'])  // 结果为1

上面没有给枚举成员赋值,所以默认为 0,如果给某一个值赋值了,后面的则递增

一个枚举类型可以包含零个或多个枚举成员。 枚举成员具有一个数字值,它可以是常数或是计算得出的值 当满足如下条件时,枚举成员被当作是常数:

  • 不具有初始化函数并且之前的枚举成员是常数。 在这种情况下,当前枚举成员的值为上一个枚举成员的值加1。 但第一个枚举元素是个例外。 如果它没有初始化方法,那么它的初始值为 0
  • 枚举成员使用常数枚举表达式初始化。 常数枚举表达式是 TypeScript 表达式的子集,它可以在编译阶段求值。 当一个表达式满足下面条件之一时,它就是一个常数枚举表达式:
    • 数字字面量
    • 引用之前定义的常数枚举成员(可以是在不同的枚举类型中定义的) 如果这个成员是在同一个枚举类型中定义的,可以使用非限定名来引用。
    • 带括号的常数枚举表达式
    • +-~ 一元运算符应用于常数枚举表达式
    • +-*/%<<>>>>>&|^ 二元运算符,常数枚举表达式做为其一个操作对象。 若常数枚举表达式求值后为 NaN 或 Infinity,则会在编译阶段报错。
enum Status {  // 定义了一个枚举 Staus,里面有三个枚举成员
  Uploading,
  Success = 5,
  Faild
}


console.log(Status.Uploading)  // 结果为 0,赋值之前的从 0 开始
console.log(Status['Success'])  // 结果为 5
console.log(Status.Faild)  // 结果为 6,会递增

也可以引用外部变量

const test = 5
enum Status {  // 定义了一个枚举 Staus,里面有三个枚举成员
  Uploading,
  Success = test,  // 引用了外部变量,之后的就也要赋值,要不然会报错 Enum member must have initializer.
  Faild = 6,
}


console.log(Status.Uploading)  // 结果为 0,赋值之前的从 0 开始
console.log(Status['Success'])  // 结果为 5
console.log(Status.Faild)  // 结果为 6,会递增

字符串枚举

枚举除了上面可以赋值为数字之外,也可以赋值字符串,如下

enum Info {
  Error = 'sorry,error',
  Success = 'ok,success',
  Faild = Error

}

console.log(Info.Error)  // sorry,error
console.log(Info.Faild)  // sorry,error。 引用了内部的 Error 枚举成员,不能引用另一个枚举里的

字符串枚举可以引用自身的枚举成员,不能引用另一个枚举里的枚举成员

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
TypeScript采坑记录发布时间:2022-07-18
下一篇:
Vue3.x 从零开始(一)—— Vue-cli or Vite 构建 TypeScript 项目发布时间:2022-07-18
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap