千家信息网

typescript如何使用枚举

发表于:2025-01-18 作者:千家信息网编辑
千家信息网最后更新 2025年01月18日,小编给大家分享一下typescript如何使用枚举,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!枚举枚举类型分为数字类型与
千家信息网最后更新 2025年01月18日typescript如何使用枚举

小编给大家分享一下typescript如何使用枚举,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

枚举

枚举类型分为数字类型与字符串类型,其中数字类型的枚举可以当标志使用:

enum AnimalFlags {    None = 0,     HasClaws = 1 << 0,     CanFly = 1 << 1,     HasClawsOrCanFly = HasClaws | CanFly }interface Animal {     flags: AnimalFlags;    [key: string]: any; }function printAnimalAbilities(animal: Animal) {     var animalFlags = animal.flags;     if (animalFlags & AnimalFlags.HasClaws) {         console.log('animal has claws');     }     if (animalFlags & AnimalFlags.CanFly) {         console.log('animal can fly');     }     if (animalFlags == AnimalFlags.None) {         console.log('nothing');     } }var animal = { flags: AnimalFlags.None }; printAnimalAbilities(animal); // nothing animal.flags |= AnimalFlags.HasClaws; printAnimalAbilities(animal); // animal has claws animal.flags &= ~AnimalFlags.HasClaws; printAnimalAbilities(animal); // nothing animal.flags |= AnimalFlags.HasClaws | AnimalFlags.CanFly; printAnimalAbilities(animal); // animal has claws, animal can fly
  • 使用 |= 来添加一个标志;

  • 组合使用 &= 和 ~ 来清理一个标志;

  • | 来合并标志。

这个或许不常用,在 typescript 关于 types 源码中我们也可以看到类似的代码:

字符串类型的枚举可以维护常量:

const enum TODO_STATUS {  TODO = 'TODO',  DONE = 'DONE',  DOING = 'DOING'}function todos (status: TODO_STATUS): Todo[];todos(TODO_STATUS.TODO)

以上是"typescript如何使用枚举"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!

0