ts枚举的两种类型是什么?

1.数字枚举和字符枚举

TS中支持两种枚举, 一种是数字枚举, 一种是字符串枚举。
(1)数字枚举
默认情况下就是数字枚举。

	enum Gender{
	    Male,
	    Female
	}
	console.log(Gender.Male);
	console.log(Gender.Female);

注意点:
数字枚举的取值默认从0开始递增。
数字枚举的取值可以是字面量, 也可以是常量, 也可以是计算的结果。

	const num = 666;
	function getNum() {
	    return 888;
	}
	enum Gender{
	    // Male = 6,
	    // Male = num, 
	    // 注意点: 如果使用常量给前面的枚举值赋值了,那么后面的枚举值也需要手动的赋值
	    // Female = 8
	    Male = getNum(), 
	    // 注意点: 如果使用计算结果给前面的枚举值赋值了, 那么后面的枚举值也需要手动的赋值
	    Female = 123
	}

(2)枚举反向映射

	enum Gender{
	    Male,
	    Female
	}
	console.log(Gender.Male); // 0
	console.log(Gender[0]); // Male

(3)字符串枚举

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

注意点:
如果使用字符串给前面的枚举值赋值了, 那么后面的枚举值也必须手动赋值。
和数字枚举不一样, 字符串枚举不能使用常量或者计算结果给枚举值赋值。
虽然字符串枚举不能够使用常量或者计算结果给枚举值赋值, 但是它可以使用内部的其它枚举值来赋值。

	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);

(4)异构枚举
枚举中既包含数字又包含字符串, 我们就称之为异构枚举。

	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)

2.枚举成员类型和联合类型

(1)枚举成员类型
我们可以把枚举成员当做类型来使用。

	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
	}

(2)联合枚举类型
联合类型就是将多种数据类型通过|连接起来。

	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
	}

3.运行时枚举和常量枚举

(1)运行时枚举
枚举在编译之后是一个真实存储的对象, 所以可以在运行时使用。
而像接口这种只是用来做约束做静态检查的代码, 编译之后是不存在的。

	interface TestInterface {
	    name:string;
	    age:number;
	}
	enum Gender{
	    Male,
	    Female
	}

(2)常量枚举
普通枚举会生成真实存在的对象。
常量枚举不会生成真实存在的对象, 而是利用枚举成员的值替换使用到的地方。

	enum Gender1{
	    Male,
	    Female
	}
	console.log(Gender1.Male === 0);
	
	const enum Gender2{
	    Male,
	    Female
	}
	console.log(Gender2.Male === 0);

阅读终点,创作起航,一起加油!

你可能感兴趣的:(typescript)