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

我們在項目開發(fā)過程中,經(jīng)常會要檢查一個數(shù)組(無序)是否包含一個特定的值?這是一個在JavaScript中經(jīng)常用到的并且非常有用的操作。
下面給出幾種實現(xiàn)方式。
方式一:利用循環(huán)
這種方式是比較老的實現(xiàn)方案,但不可否認的是在瀏覽器中效率較高。
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;}
方式二:使用數(shù)組的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此方法判斷數(shù)組中是否存在某個值,如果存在返回數(shù)組元素的下標(biāo),否則返回-1。
[].indexOf(1);//0[].indexOf("fly63");//1[].indexOf(4);//-1
注意點:
1、indexOf() 方法對大小寫敏感!如果要檢索的字符串值沒有出現(xiàn),則該方法返回 -1。
2、在比較第一個參數(shù)與數(shù)組中的每一項時,會使用全等操作符,即要求查找的項必須嚴格相等
3、數(shù)組的位置是ECMAScript5為數(shù)組實例新增的,支持的瀏覽器有IE9+,Firefox,Safari,Opera,Chrome
方式四:array.includes
array.includes(searchElement[, fromIndex]) 此方法判斷數(shù)組中是否存在某個值,如果存在返回 true,否則返回false。
它可以像這樣使用:
[].includes(2); // true[].includes(4); // false
它還接受可選的第二個參數(shù)fromIndex:
[].includes(3, 3); // false[].includes(3, -1); // true
不像indexOf,它采用嚴格相等比較。這意味著您可以檢測數(shù)組是否包含NaN:
[1, 2, NaN].includes(NaN); // true
也不同于indexOf,includes不會跳過缺失的索引:
new Array(5).includes(undefined); // true
方式五:array.find
find用于返回數(shù)組中滿足條件的第一個元素的值,如果沒有,返回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。返回數(shù)組中滿足條件的第一個元素的索引(下標(biāo)), 如果沒有找到,返回-1 同第3種方法類似。
方式六、利用set中has方法
function contains(arr, val) {return new Set(arr).has(val)}contains([1,2,3],2);//true
通過new set([])將數(shù)組轉(zhuǎn)換成Set對象,set.prototype.has(value)判斷該值是否存在于Set對象中,返回布爾值。
延伸:除此之外,還可以利用它進行數(shù)組去重,比如:
let arr2 = new Set([1,1,2,3,4])let arr3 = [...arr2]console.log(arr2, arr3) // {1,2,3,4} [1,2,3,4]
學(xué)習(xí)更多技能
請點擊下方公眾號
![]()

