Array.includes()函数的用法
在ES5,Array已经提供了indexOf用来查找某个元素的位置,如果不存在就返回-1,但是这个函数在判断数组是否包含某个元素时有两个小不足,第一个是它会返回-1和元素的位置来表示是否包含,在定位方面是没问题,就是不够语义化。另一个问题是不能判断是否有NaN的元素。
1
2
|
const arr1 = [
'a'
,
'b'
,
'c'
,
'd'
,
'e'
,
'f'
,
'g'
,
'h'
,
'i'
,
'j'
,
'k'
, NaN]
console.log(
'%s'
, arr1.indexOf(NaN))
|
结果:
-1
ES6提供了Array.includes()函数判断是否包含某一元素,除了不能定位外,解决了indexOf的上述的两个问题。它直接返回true或者false表示是否包含元素,对NaN一样能有有效。
1
2
3
4
|
const arr1 = [
'a'
,
'b'
,
'c'
,
'd'
,
'e'
,
'f'
,
'g'
,
'h'
,
'i'
,
'j'
,
'k'
, NaN]
console.log(
'%s'
, arr1.includes(
'c'
))
console.log(
'%s'
, arr1.includes(
'z'
))
console.log(
'%s'
, arr1.includes(NaN))
|
结果:
true
false
true
includes()函数的第二个参数表示判断的起始位置。
1
2
3
4
|
const arr1 = [
'a'
,
'b'
,
'c'
,
'd'
,
'e'
,
'f'
,
'g'
,
'h'
,
'i'
,
'j'
,
'k'
, NaN]
console.log(
'%s'
, arr1.includes(
'd'
, 1))
console.log(
'%s'
, arr1.includes(
'd'
, 3))
console.log(
'%s'
, arr1.includes(
'd'
, 4))
|
结果:
true
true
false
第二个参数也可以是负数,表示从右数过来第几个,但是不改变判断搜索的方向,搜索方向还是从左到右。
1
2
3
|
console.log(
'%s'
, arr1.includes(
'k'
, -1))
console.log(
'%s'
, arr1.includes(
'k'
, -2))
console.log(
'%s'
, arr1.includes(
'i'
, -3))
|
结果:
false
true
false
includes():返回布尔值,表示是否找到了参数字符串。这三个方法都支持第二个参数,表示开始搜索的位置。