![](/img/trans.png)
[英]How to use Array.protoype.map() on array of objects to filter out some specific keys based on it's values?
[英]how to filter keys based on values in a array of objects
我想根据键值对中的值过滤对象。
我想要只有真实的键。
尝试使用array.filter
但我找不到解决方案。
例如:-
const arry = [{'fname': true}, {'lname': true}, {'country': false}];
有人可以帮助我如何提取具有真实值的键。
预期o / p
['fname','lname'],因为它们是唯一正确的值。
您可以减少数组,获取第一个条目的条目并检查值。 如果值为真,请按键。
var array = [{ fname: true }, { lname: true }, { country: false }], keys = array.reduce((r, o) => { var [key, value] = Object.entries(o)[0]; if (value) r.push(key); return r; }, []); console.log(keys);
Array.filter
带有应返回true或false的函数,该函数指示是否应保留数组中的特定元素。
您有一个数组对象,并且对象本身可以具有多个键和值。 您需要在这里执行一个多步骤的过程:
您可以使用Object.assign合并对象。 我们将使用Array.reduce将对象数组简化为单个对象:
const combined = arry.reduce((acc, val) => Object.assign({}, acc, val))
这将导致包含所有键值对的单个对象:
// { country: false, fname: true, lname: true}
现在,我们只需要选择具有真实值的条目即可生成一个数组数组:
const entries = Object.entries(combined).filter(([k, v]) => v)
// [["lname", true], ["fname", true]]
然后,我们可以映射出该数组中的键,如下所示:
entries.map(([k, v]) => k)
// ["lname", "fname"]
为了简洁起见,这些步骤都可以链接在一起。
const arry = [{'fname': true}, {'lname': true}, {'country': false}]; Object.entries(arry.reduce((acc, val) => Object.assign({}, acc, val))) .filter(([k, v]) => v) .map(([k, v]) => k)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.