<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

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

          共 2418字,需瀏覽 5分鐘

           ·

          2021-10-17 21:55


          我們在項目開發(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。

          [1, 2, 3].indexOf(1);//0["foo", "fly63", "baz"].indexOf("fly63");//1[1, 2, 3].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。

          它可以像這樣使用:

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

          它還接受可選的第二個參數(shù)fromIndex:

          [1, 2, 3].includes(3, 3); // false[1, 2, 3].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í)更多技能

          請點擊下方公眾號

          瀏覽 95
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  欧美精品导航 | 欧美成人A猛片 | 91麻豆午夜视频 | 精品国产91久久久久久暴行片 | 欧美麻豆一区 |