js中修改数组对象中对象的键名

场景分析:一个数据字典列表,如下

let dictList = [
	{id: 1, name: "sn", desc: "序列号"},
	{id: 2, name: "prop", desc: "属性"},
	{id: 3, name: "type", desc: "类型"},
	{id: 4, name: "user", desc: "负责人"}
]

后台返回的数据列表,如

let data = [
	{sn: 121, user: "张氏"},
	{sn: 122, prop: "属性1", type: "类型1"},
	{prop: "属性1", type: "类型1", user: "李四"},
]

需求:后台返回的数据列表想用表格展示,这个数据列表中每个对象返回的键值对是不固定的,但是取值是从数据字典中取来的。为了方便展示,想把后台返回的数据列表中对象的键改为数据字典中对应 namedesc 字段,就动态修改对象的键名。
做法:
我们可以先将数据字典列表转换为一个对象 labels

let labels = {}
dictList.forEach(item => {
 this.$set(labels, item.name, item.desc)
})
console.log(labels)
// {
  'sn': '序列号',
  'prop': '属性',
  'type': '类型',
  'user': '负责人'
}

然后修改后台数据列表的对象键名

let res = data.map(item => {
 let obj = {}
 Object.entries(item).forEach(([k, v]) => {
   obj[labels[k] || k] = v
 })
 return obj
})
console.log(res )

这种做法适合用于返回的数组对象中,对象的属性不固定的情况

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值