一:一个对象,过滤掉键对应的值是空数组的键,保留值不是空数组的键值对
const obj = {
a: [1, 2, 3],
b: [],
c: [4, 5],
d: [],
e: [6]
};
// 过滤掉值为空数组的键值对
const filteredObj = Object.fromEntries(
Object.entries(obj).filter(([key, value]) => value.length > 0)
);
console.log(filteredObj);
二:过滤掉一个对象中键对应的值为 [{}] 的键值对,并将这些键值对的值替换为 []
const obj = {
a: [1, 2, 3],
b: [{}],
c: [4, 5],
d: [{}],
e: [6],
f: [{ key: 'value' }]
};
// 过滤掉值为 [{}] 的键值对,并将它们的值替换为 []
const filteredObj = Object.fromEntries(
Object.entries(obj).map(([key, value]) => {
if (Array.isArray(value) &&value.length === 1 &&Object.keys(value[0]).length === 0) {
return [key, []];
}
return [key, value];
})
);
console.log(filteredObj);
注:Object.entries()和Object.fromEntries()
Object.entries()方法返回一个给定对象自身可枚举属性的键值对数组。
Object.fromEntries()方法将键值对列表转化为一个对象。
const obj = { a: 1, b: 2, c: 3 };
const entries = Object.entries(obj);
console.log(entries); // [["a", 1], ["b", 2], ["c", 3]]
const entries = [["a", 1], ["b", 2], ["c", 3]];
const obj = Object.fromEntries(entries);
console.log(obj); // { a: 1, b: 2, c: 3 }