Js判断数组是否包含某个值

时间:?2021-10-14阅读:?19标签:?数组

大家在项目开发过程中,经常会要检查一个数组(无序)是否包含一个特定的值?这是一个在js中经常用到的并且非常有用的操作。下面给出几种实现方式


方式一:利用循环

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

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]


站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

链接: http://www.pannellisolari.net/article/detial/10736

javascript怎么定义二维数组?

数组对象的作用是:使用单独的变量名来存储一系列的值。相信大家都知道如何定义一维数组,那么大家知道如何定义二维数组吗?

[译]async-await 数组循环的几个坑

在 Javascript 循环中使用 async/ await 循环遍历数组似乎很简单,但是在将两者结合使用时需要注意一些非直观的行为。让我们看看三个不同的例子,看看你应该注意什么,以及哪个循环最适合特定用例。

js数组去重的方法

在实际工作或面试中,我们经常会遇到“数组去重”问题,接下来就是使用js实现的数组去重的多种方法:

了解JavaScript中的伪数组

JavaScript中存在有一种类数组,或者说伪数组。经常见到的伪数组有函数的arguments对象,dom.querySelectorAll等获取的NodeList类(NodeList本身具有forEach方法)等。伪数组并不是数组,它没有继承Array.prototype

探索JavaScript数组奥秘

avaScript数组同后端语言一样,具有它自己的数据结构,归根结底,这种数据结构,本质就是一种集合。在后端语言中(如java,.net等),数组是这样定义的:数组是用来存储相同数据类型的集合

JS计算两个数组的交集,差集,并集,补集(多种实现方式)

使用 ES5 语法来实现虽然会麻烦些,但兼容性最好,不用考虑浏览器 JavaScript 版本,使用 ES5 语法来实现虽然会麻烦些,但兼容性最好,不用考虑浏览器 JavaScript 版本。也不用引入其他第三方库。

Js Array数组方法总结

合并数组 - concat();数组转字符串 - join(),toString();删除数组最后一个元素 - pop();添加元素 - push();数组反转 - reverse();删除数组第一个元素 - shift();截取数组元素 - slice

JavaScrip数组去重操作实例

这篇文章主要介绍了JavaScrip数组去重操作,结合实例形式总结分析了javascript针对数组的遍历,判断,去重等相关操作技巧,需要的朋友可以参考下。本文实例讲述了JavaScrip数组去重操作。分享给大家供大家参考,具体如下:

js数组中filter,map,reduce,find等方法实现的原理

filter 过滤,filter()使用指定的函数测试所有元素,并创建一个包含所有通过测试的元素的新数组。map 映射,map()方法返回一个新数组,数组中的元素为原始数组元素调用函数处理的后值。

Js数组展开(扁平化)和underscore的 flatten

数组展开就是将嵌套的数组扁平化(转换为一维的),1,判断每一项是否是数组,然后递归;2,toString;3,reduce方法;4,解构的方式;6,Underscore.js的flatten方法

点击更多...

内容以共享,参考,研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!

Baidu