Object.entries()和Object.fromEntries()

一:一个对象,过滤掉键对应的值是空数组的键,保留值不是空数组的键值对

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 }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值