欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

es6数组includes()用法实例分析

程序员文章站 2022-07-06 17:56:00
本文实例讲述了es6数组includes()用法。分享给大家供大家参考,具体如下:array.prototype.includes方法返回一个布尔值,表示某个数组是否包含给定的值,与字符串的inclu...

本文实例讲述了es6数组includes()用法。分享给大家供大家参考,具体如下:

array.prototype.includes方法返回一个布尔值,表示某个数组是否包含给定的值,与字符串的includes方法类似。es2016引入了该方法。

[1, 2, 3].includes(2) // true
[1, 2, 3].includes(4) // true
[1, 2, nan].includes(nan) // true

该方法的第二个参数表示搜索的起始位置,默认为0。如果第二个参数为负数,则表示倒数的位置,如果这时它大于数组长度(比如第二个参数为-4, 但数组长度为3),则会重置为0开始。

[1, 2, 3].includes(3, 3); // false
[1, 2, 3].includes(3, -1); // true

没有该方法之前,我们通常使用数组的indexof方法,检查是否包含某个值。

if (arr.indexof(el) !== -1) {
 // ...
}

indexof方法有两个缺点,一是不够语义化,它的含义是找到参数值的第一个出现位置,所以要去比较是否不等于-1,表达起来不够直观。二是,它内部使用严格相等运算符进行判断,这会导致对nan的误判。

[nan].indexof(nan) // -1

includes使用的是不一样的判断算法,就没有这个问题。

[nan].includes(nan) // true

下面代码用来检查当前环境是否支持该方法,如果不支持,部署一个简易的替代版本。

const contains = (() => array.prototype.includes 
? (arr, value) => arr.includes(value)
:(arr, value) => arr.some(el => el === value) 
)()

另外,map和set数据结构有一个has方法需要注意与includes区分。

-map结构的has方法,是用来查找键名的,比如map.prototype.has(key),
weakmap.prototype.has(key), reflect.has(target, propertykey)

-set结构的has方法,是用来查找值的,比如set.prototype.has(value),
weakset.prototype.has(value)

感兴趣的朋友可以使用在线html/css/javascript代码运行工具http://tools.jb51.net/code/htmljsrun测试上述代码运行效果。