首頁  >  文章  >  web前端  >  es6怎麼判斷數組中是否包含某項值

es6怎麼判斷數組中是否包含某項值

青灯夜游
青灯夜游原創
2022-03-07 18:35:3110441瀏覽

在es6中,可以利用數組的includes()方法來判斷數組中是否包含某一項值,該方法可以用來檢測數組中是否包含某個值,語法“數組對象.includes(值)」。

es6怎麼判斷數組中是否包含某項值

本教學操作環境:windows7系統、ECMAScript 6版、Dell G3電腦。

在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

總結:

includes()方法,用來偵測陣列中是否包含某個值,可以判斷NaN,而且直接傳回true/false ,比較直覺;

indexOf()方法,用來找出某個元素的位置,不能判斷NaN,回傳-1,即不包含,非-1即目前包含的位置。

兩個方法各有長短,依實際情況定。如果元素包含NaN,就用includes(),否則兩者皆可。

【相關推薦:javascript影片教學web前端

以上是es6怎麼判斷數組中是否包含某項值的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn