1. <strong id="7actg"></strong>
    2. <table id="7actg"></table>

    3. <address id="7actg"></address>
      <address id="7actg"></address>
      1. <object id="7actg"><tt id="7actg"></tt></object>

        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ù)組元素的下標,否則返回-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ù)組中滿足條件的第一個元素的索引(下標), 如果沒有找到,返回-1 同第3種方法類似。

        方式六、利用set中has方法

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

        通過new set([])將數(shù)組轉換成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]


        學習更多技能

        請點擊下方公眾號

        瀏覽 95
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

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

        手機掃一掃分享

        分享
        舉報
        1. <strong id="7actg"></strong>
        2. <table id="7actg"></table>

        3. <address id="7actg"></address>
          <address id="7actg"></address>
          1. <object id="7actg"><tt id="7actg"></tt></object>
            欧美久久精品 | 波多野结衣无码电影 | 用力灬受不了了 | 777精品 | 第一色综合 | 亚洲黄色中文字幕 | 午夜免费毛片 | 欧美21p| 无码人妻精品一区二区蜜桃漫画 | 日韩理论片久久 |