TypeScript-枚举

详情可见
1.数字枚举

默认情况下就是数字枚举
enum Gender{
    Male,
    Female
}
console.log(Gender.Male);
console.log(Gender.Female);

2.数字枚举注意点

// 数字枚举的取值默认从0开始递增
// 数字枚举的取值可以是字面量, 也可以是常量, 也可以是计算的结果
const num = 666;
function getNum() {
    return 888;
}
enum Gender{
    // Male = 6,
    // Male = num, // 注意点: 如果使用常量给前面的枚举值赋值了, 那么后面的枚举值也需要手动的赋值
    // Female = 8
    Male = getNum(), // 注意点: 如果使用计算结果给前面的枚举值赋值了, 那么后面的枚举值也需要手动的赋值
    Female = 123
}

3.枚举反向映射

// 可以根据枚举值获取到原始值
// 也可以根据原始值获取到枚举值
enum Gender{
    Male,
    Female
}
console.log(Gender.Male); // 0
console.log(Gender[0]); // Male

4.字符串枚举

enum Gender{
    Male = 'www.it666.com',
    Female = 'www.itzb.com' // 注意点: 如果使用字符串给前面的枚举值赋值了, 那么后面的枚举值也必须手动赋值
}
console.log(Gender.Male);
console.log(Gender.Female);

5.字符串枚举注意点

注意点: 如果使用字符串给前面的枚举值赋值了, 那么后面的枚举值也必须手动赋值
注意点: 和数字枚举不一样, 字符串枚举不能使用常量或者计算结果给枚举值赋值
注意点: 虽然字符串枚举不能够使用常量或者计算结果给枚举值赋值, 但是它可以使用内部的其它枚举值来赋值
const str = 'lnj';
function getStr() {
    return 'abc';
}
enum Gender{
    Male = 'www.it666.com',
    // Male = str,
    // Male = getStr(),
    Female = 'www.itzb.com',
    Yao = Female
}
console.log(Gender.Female);
console.log(Gender.Yao);

6.异构枚举

// 枚举中既包含数字又包含字符串, 我们就称之为异构枚举
enum Gender{
    Male = 6,
    Female = 'nv'
}

console.log(Gender.Male);
console.log(Gender.Female);
console.log(Gender[6]);
// 注意点: 如果是字符串枚举, 那么无法通过原始值获取到枚举值
// console.log(Gender['nv']);
console.log(Gender);

7.枚举成员类型

// 我们就可以把枚举成员当做类型来使用
enum Gender{
    Male = 'www.it666.com',
    Female = 'www.itzb.com'
}
interface TestInterface {
    age: Gender.Male
}
class Person implements TestInterface{
    age: Gender.Male
    // age: Gender.Female // 由于类型不匹配, 所以会报错
    // age: 0 // 注意点: 由于数字枚举的本质就是数值, 所以这里写一个数值也不会报错

    // age: Gender.Male
    // age: Gender.Female
    // age: 'www.it666.com' // 注意点: 如果是字符串枚举, 那么只能是枚举成员的值, 不能是其它的值
    // age: string
}

8.联合枚举类型

// 2.1什么是联合类型?
// 联合类型就是将多种数据类型通过|连接起来
// 我们可以把枚举类型当做一个联合类型来使用

let value:(number | string); // (number | string)联合类型
value = 1;
value = 6;
value = "123";

enum Gender{
    Male ,
    Female
}
interface TestInterface {
    age: Gender // age: (Gender.Male | Gender.Female)
}
class Person implements TestInterface{
    // age: Gender.Male
    age: Gender.Female
}

9.运行时枚举

运行时枚举
枚举在编译之后是一个真实存储的对象, 所以可以在运行时使用
而像接口这种只是用来做约束做静态检查的代码, 编译之后是不存在的
interface TestInterface {
    name:string;
    age:number;
}
enum Gender{
    Male,
    Female
}

10.常量枚举

普通枚举和常量枚举的区别
普通枚举会生成真实存在的对象
常量枚举不会生成真实存在的对象, 而是利用枚举成员的值直接替换使用到的地方
enum Gender1{
    Male,
    Female
}
console.log(Gender1.Male === 0);

const enum Gender2{
    Male,
    Female
}
console.log(Gender2.Male === 0);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: TypeScript枚举是一种数据类型,用于定义一组命名的常量。枚举可以帮助开发人员更好地组织代码,并提高代码的可读性和可维护性。枚举可以包含数字、字符串或混合类型的值,并且可以具有自定义的值。在TypeScript中,枚举可以通过名称或值进行访问。枚举还可以用于类型注释和类型推断。 ### 回答2: Typescript枚举是一种为具体值赋予有意义的名称的数据类型。枚举可以理解为定义了一组定义的常量集合,可以使用这些常量来表示某个特定的状态或值。 在Typescript中,我们使用`enum`关键字来创建一个枚举类型。例如,我们可以创建一个表示颜色的枚举类型: ``` enum Color { Red, Green, Blue } ``` 在这个例子中,我们定义了一个名为Color的枚举类型,包含了三个常量值Red、Green和Blue。默认情况下,这些常量的值将依次递增,从0开始。可以通过指定值来改变默认的递增行为: ``` enum Color { Red = 1, Green = 2, Blue = 4 } ``` 在这个例子中,我们将Red的值设置为1,Green的值设置为2,Blue的值设置为4。 枚举类型可以用于表示一系列的选项,通过使用枚举名和常量名称来访问具体的值。例如,我们可以使用Color.Red来表示红色。 枚举类型还可以使用枚举的值来进行比较和判断,这样可以避免使用魔法数值。此外,枚举类型还提供了一些便利的方法,例如`Object.keys(Color)`可以用于获取枚举中所有常量的名称。 总之,Typescript枚举是一种方便的数据类型,能够为常量赋予可读性高的名称,提高代码的可维护性和可读性。 ### 回答3: TypeScript枚举是一种用于定义一组具有命名值的数据类型。它可以提供更好的代码可读性和可维护性。 枚举使用关键字"enum"来定义,并且可以包含一个或多个枚举成员。每个枚举成员都有一个名称和与之关联的值。这些值可以是数字、字符串或布尔值。 枚举的优势之一是可以使用值或名称来访问枚举成员。例如,如果有一个颜色的枚举,可以通过值来访问相应的名称,或者通过名称来访问相应的值。 枚举成员也可以指定一个初始值。如果没有指定初始值,那么枚举成员的值将会自动递增。 枚举还支持反向映射。这意味着可以通过枚举成员的值来获取相应的名称,或通过名称来获取相应的值。 枚举还可以使用具有枚举成员值的表达式进行计算。这在一些复杂的场景中非常有用。 另一个有用的功能是可以将枚举用作类型。这样,变量只能取枚举成员的值,而不能取其他任何值。 总结而言,TypeScript枚举是一种有助于提高代码可读性和可维护性的数据类型。它提供了更好的代码组织和更明确的值表示方式,并且支持访问和计算枚举成员的各种功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值