用 JavaScript 编写枚举的最有效方法

本文介绍了如何从 Vue 源码中获取灵感,使用二进制位操作来优化枚举的定义和使用,提高代码效率。通过示例展示了如何定义和检查枚举项,同时指出这种方法的限制在于枚举项不能超过 31 个。性能测试显示,使用位运算的枚举比传统的数组或映射方法更具优势。
摘要由CSDN通过智能技术生成

假设有这样一个场景,我们需要统计员工的技术栈,目前我们需要标记的技术有 CSS、JavaScript、HTML、WebGL。

然后我可以这样写枚举:

const SKILLS = {
 CSS: 1 ,
 JS: 2,
 HTML: 3,
 WEB_GL: 4
}

之前是这样写的,但是,最近看vue源码的时候,发现了一个高效使用枚举的技巧,在这里分享给大家。

定义枚举

我们可以这样写上面的枚举:

const SKILLS = {
 CSS: 1 ,
 JS: 1 << 1,
 HTML: 1 << 2,
 WEB_GL: 1 << 3
}

<< 是什么?

左移运算符 (<<) 将第一个操作数左移指定位数。向左移动的多余位被丢弃。零位从右侧移入。

例如:

  • 二进制的 1 是 0000 0001 ,左移一位是 0000 0010 ,即十进制的 2 。
  • 如果我们将其移动两位,它将变为 0000 0100 ,即十进制的 4。
  • 如果我们将其移动三位,它将变为 0000 1000 ,即十进制的 8。
  • 如果我们将其移动 N 位,它将变为 2^Nin 十进制。

用法

按照上面的方法定义好枚举后,我们可以这样使用:

const SKILLS = {
 CSS: 1 ,
 JS: 1 <<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值