
我們在項目開發過程中,經常會要檢查一個數組(無序)是否包含一個特定的值?這是一個在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]
學習更多技能
請點選下方公衆号