天天看點

6種JavaScript判斷數組是否包含某個值的方法

6種JavaScript判斷數組是否包含某個值的方法

我們在項目開發過程中,經常會要檢查一個數組(無序)是否包含一個特定的值?這是一個在JavaScript中經常用到的并且非常有用的操作。

下面給出幾種實作方式。

方式一:利用循環

這種方式是比較老的實作方案,但不可否認的是在浏覽器中效率較高。

function contains(arr, val) {
    for (var i = 0; i < arr.length; i++) {
        if (arr[i] === val) {
            return true;
        }
    }
    return false;
}
contains([1,2,3],3);//true      

或者使用while:

function contains(arr, val) {
    var i = arr.length;
    while (i--) {
       if (arr[i] === val){
           return true;
       }
    }
    return false;
}      

方式二:使用數組的some,filter等方法

使用some方法更簡潔,一旦找到元素,疊代就會中止,進而避免了不必要的疊代周期。​

function contains(arr, val) {
    return arr.some(item => item === val);
}      

使用filter(注意:array.filter(e=>e==x).length > 0等效于array.some(e=>e==x)但some更有效)​

function contains(arr, val) {
    return arr.filter((item)=> { return item == val }).length > 0;
}      

方式三:array.indexOf

array.indexOf此方法判斷數組中是否存在某個值,如果存在傳回數組元素的下标,否則傳回-1。

[1, 2, 3].indexOf(1);//0
["foo", "fly63", "baz"].indexOf("fly63");//1
[1, 2, 3].indexOf(4);//-1      

注意點:

1、indexOf() 方法對大小寫敏感!如果要檢索的字元串值沒有出現,則該方法傳回 -1。

2、在比較第一個參數與數組中的每一項時,會使用全等操作符,即要求查找的項必須嚴格相等

3、數組的位置是ECMAScript5為數組執行個體新增的,支援的浏覽器有IE9+,Firefox,Safari,Opera,Chrome

方式四:array.includes

array.includes(searchElement[, fromIndex]) 此方法判斷數組中是否存在某個值,如果存在傳回 true,否則傳回false。

它可以像這樣使用:

[1, 2, 3].includes(2); // true
[1, 2, 3].includes(4); // false      

它還接受可選的第二個參數fromIndex:

[1, 2, 3].includes(3, 3); // false
[1, 2, 3].includes(3, -1); // true      

不像indexOf,它采用嚴格相等比較。這意味着您可以檢測數組是否包含NaN:

[1, 2, NaN].includes(NaN); // true      

也不同于indexOf,includes不會跳過缺失的索引:​

new Array(5).includes(undefined); // true      

方式五:array.find

find用于傳回數組中滿足條件的第一個元素的值,如果沒有,傳回undefined,比如:​

let numbers = [12, 5, 8, 130, 44];
let result = numbers.find(item => {
    return item > 8;
});
console.log(result);//12
//元素是對象
let items = [
    {id: 1, name: 'something'},
    {id: 2, name: 'anything'},
    {id: 3, name: 'nothing'},
];
let item = items.find(item => {
    return item.id == 3;
});
console.log(item) //Object { id: 3, name: "nothing" }      

除了find,我們也可以使用array.indIndex。傳回數組中滿足條件的第一個元素的索引(下标), 如果沒有找到,傳回-1 同第3種方法類似。

方式六、利用set中has方法

function contains(arr, val) {
  return new Set(arr).has(val)
}
contains([1,2,3],2);//true      

通過new set([])将數組轉換成Set對象,set.prototype.has(value)判斷該值是否存在于Set對象中,傳回布爾值。

延伸:除此之外,還可以利用它進行數組去重,比如:​

let arr2 = new Set([1,1,2,3,4])
let arr3 = [...arr2]
console.log(arr2, arr3) // {1,2,3,4} [1,2,3,4]      

學習更多技能

請點選下方公衆号