我们在项目开发过程中,经常会要检查一个数组(无序)是否包含一个特定的值?这是一个在中经常用到的并且非常有用的操作。

下面给出几种实现方式。

方式一:利用循环

这种方式是比较老的实现方案,但不可否认的是在浏览器中效率较高。

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,等方法

使用some方法更简洁,一旦找到元素,迭代就会中止,从而避免了不必要的迭代周期。

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

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

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

方式三:array.

array.此方法判断数组中是否存在某个值,如果存在返回数组元素的下标,否则返回-1。

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

注意点:

1、() 方法对大小写敏感!如果要检索的字符串值没有出现,则该方法返回 -1。

2、在比较第一个参数与数组中的每一项时,会使用全等操作符,即要求查找的项必须严格相等

3、数组的位置是为数组实例新增的,支持的浏览器有IE9+,,,Opera,

方式四:array.

array.([, ]) 此方法判断数组中是否存在某个值,如果存在返回 true,否则返回false。

它可以像这样使用:

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

它还接受可选的第二个参数:

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

不像,它采用严格相等比较。这意味着您可以检测数组是否包含NaN:

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

也不同于,不会跳过缺失的索引:

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

方式五:array.find

find用于返回数组中满足条件的第一个元素的值,如果没有,返回,比如:

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.。返回数组中满足条件的第一个元素的索引(下标), 如果没有找到,返回-1 同第3种方法类似。

方式六:利用set中has方法

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

通过new set([])将数组转换成Set对象,set..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]

———END———
限 时 特 惠: 本站每日持续更新海量各大内部创业教程,永久会员只需109元,全站资源免费下载 点击查看详情
站 长 微 信: nanadh666

声明:1、本内容转载于网络,版权归原作者所有!2、本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。3、本内容若侵犯到你的版权利益,请联系我们,会尽快给予删除处理!