js对象数组查找某一元素的各种方法(不改变原数组)
作者:慢慢雨夜
前端经常要通过javaScript来处理数组中的数据,其中就包括检查数组中是否包含满足特定搜索条件的单个或者多个值,这篇文章主要给大家介绍了关于js对象数组查找某一元素的各种方法,文中介绍的方法不改变原数组,需要的朋友可以参考下
find()方法
这个方法会返回数组中第一个符合条件的元素,如果没有符合条件的元素则返回undefined。
const arr = [{name: '张三', age: 20}, {name: '李四', age: 30}, {name: '王五', age: 25}] const result = arr.find(item => item.name === '李四') //result = {name: '李四', age: 30}
filter()方法
这个方法会返回符合条件的元素组成的新数组,如果没有符合条件的元素则返回空数组。
const arr = [{name: '张三', age: 20}, {name: '李四', age: 30}, {name: '王五', age: 25}] const result = arr.filter(item => item.age > 20) // result = [{name: '李四', age: 30}, {name: '王五', age: 25}]
some()方法
这个方法会返回一个布尔值,表示数组中是否存在至少一个符合条件的元素。
const arr = [{name: '张三', age: 20}, {name: '李四', age: 30}, {name: '王五', age: 25}] const result = arr.some(item => item.name === '李四') // result = true
findIndex()方法
这个方法会返回数组中第一个符合条件的元素的索引,如果没有符合条件的元素则返回-1。
const arr = [{name: '张三', age: 20}, {name: '李四', age: 30}, {name: '王五', age: 25}] const result = arr.findIndex(item => item.name === '李四') // result = 1
forEach()方法
这个方法可以遍历整个数组,通过判断每一个元素是否符合条件来找到目标元素。
const arr = [{name: '张三', age: 20}, {name: '李四', age: 30}, {name: '李四', age: 66}] let result arr.forEach(item => { if (item.name === '李四') { result = item } }) // result = {name: '李四', age: 66}
注意:以上方法都不会改变原数组,如果想要改变原数组可以使用splice()方法。
附:js检查对象数组中的每个对象是否包含另一个数组中的属性,并取出相同的值
检查数组对象是否包含另一个数组的值,并取出相同的数组对象。
例子:
返回结果:
[{name:"zangsan",age:"18"},{name:"wangwu",age:"12"}]
js代码:
const movies = [ {name:"zangsan",age:"18"}, {name:"zhaoliu",age:"21"}, {name:"wangwu",age:"12"} ]; const filters = ["zangsan", "wangwu"]; const res = movies.filter( movie => Object.values(movie).some(v => filters.includes(v)) ); console.log(res);
总结
到此这篇关于js对象数组查找某一元素的各种方法的文章就介绍到这了,更多相关js对象数组查找某一元素内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!