本文主要和大家介紹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一樣能有有效。
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()函數的第二個參數表示判斷的起始位置。
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
第二個參數也可以是負數,表示從右數過來第幾個,但是不改變判斷搜尋的方向,搜尋方向還是從左到右。
console.log('%s', arr1.includes('k', -1)) console.log('%s', arr1.includes('k', -2)) console.log('%s', arr1.includes('i', -3))
結果:
false
true
false
相關推薦:
以上是ES6中Array.includes()函數如何使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!