溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

es6如何判斷數(shù)組中是否包含某一項值

發(fā)布時間:2022-03-08 09:37:47 來源:億速云 閱讀:1007 作者:小新 欄目:web開發(fā)

小編給大家分享一下es6如何判斷數(shù)組中是否包含某一項值,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

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

本教程操作環(huán)境:windows7系統(tǒng)、ECMAScript 6版、Dell G3電腦。

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

例如:

const arr1 = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', NaN]
console.log('%s', arr1.indexOf(NaN))

結(jié)果:

-1

ES6提供了Array.includes()函數(shù)判斷是否包含某一元素,除了不能定位外,解決了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))

結(jié)果:

true
false
true

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

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

結(jié)果:

true
true
false

第二個參數(shù)也可以是負數(shù),表示從右數(shù)過來第幾個,但是不改變判斷搜索的方向,搜索方向還是從左到右。

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

結(jié)果:

false
true
false

總結(jié):

includes()方法,用來檢測數(shù)組中是否包含某個值,可以判斷NaN,而且直接返回true/false,比較直觀;

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

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

看完了這篇文章,相信你對“es6如何判斷數(shù)組中是否包含某一項值”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

es6
AI