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对象数组查找某一元素内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论