林娜尔优秀作者
原创内容 来源:小居数码网 时间:2024-08-15 17:32:02 阅读() 收藏:45 分享:59 爆
导读:您正在阅读的是关于【数码知识】的问题,本文由科普作家协会,生活小能手,著名生活达人等整理监督编写。本文有974个文字,大小约为4KB,预计阅读时间3分钟。
我们在项目开发过程中,经常会要检查一个数组(无序)是否包含一个特定的值?这是一个在JavaScript中经常用到的并且非常有用的操作。
下面给出几种实现方式。
这种方式是比较老的实现方案,但不可否认的是在浏览器中效率较高。
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方法更简洁,一旦找到元素,迭代就会中止,从而避免了不必要的迭代周期。
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此方法判断数组中是否存在某个值,如果存在返回数组元素的下标,否则返回-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(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
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种方法类似。
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]
上面就是小居数码小编今天给大家介绍的关于(JS判断数组是否包含某个值)的全部内容,希望可以帮助到你,想了解更多关于数码知识的问题,欢迎关注我们,并收藏,转发,分享。
94%的朋友还想知道的:
(511)个朋友认为回复得到帮助。
部分文章信息来源于以及网友投稿,转载请说明出处。
本文标题:js判断数组中是否有某个值(JS判断数组是否包含某个值):http://sjzlt.cn/shuma/155925.html