ES6,Array.includes()函數的用法

在ES5,Array已經提供了indexOf用來查找某個元素的位置,若是不存在就返回-1,可是這個函數在判斷數組是否包含某個元素時有兩個小不足,第一個是它會返回-1和元素的位置來表示是否包含,在定位方面是沒問題,就是不夠語義化。另外一個問題是不能判斷是否有NaN的元素。數組

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同樣能有有效。spa

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))

結果:code

true
false
true

 

includes()函數的第二個參數表示判斷的起始位置。blog

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))

結果:console

true
true
false

 

第二個參數也能夠是負數,表示從右數過來第幾個,可是不改變判斷搜索的方向,搜索方向仍是從左到右。class

console.log('%s', arr1.includes('k', -1))
console.log('%s', arr1.includes('k', -2))
console.log('%s', arr1.includes('i', -3))

結果:搜索

false
true
false

 

Enddi

相關文章
相關標籤/搜索