es6数组includes()⽤法实例分析
本⽂实例讲述了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
indexof能用于数组吗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)
更多关于JavaScript相关内容可查看本站专题:《》、《》、《》、《》及《》
希望本⽂所述对⼤家JavaScript程序设计有所帮助。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论