替换数组值的键对象

问题描述 投票:0回答:2

我在替换对象中的键时遇到问题

let headers = ['title1', 'title2', 'title3']

let obj = {
    0: ['name1', 'name2, 'name3],
    1: ['example1', 'example2, 'example3],
    2: ['xx', 'yy, 'zz],
}

我想做的是:

let obj = {
   'title1': ['name1', 'name2, 'name3],
   'title2': ['example1', 'example2, 'example3],
   'title3': ['xx', 'yy, 'zz],
}

我不确定我的方法是否正确:

  Object.keys(obj).map((el, index, arr) => {
      headers.forEach((item, item_index) => {
          arr[item_index] = item
      })
  })

当我

console.log(Object.keys(obj))
我仍然得到:
0,1,2
....

json loops object ecmascript-6 key
2个回答
1
投票

Object.values 仅返回指定的

obj
中的值,并且 Object.fromEntries 允许您基于数组的二元素列表创建新对象:

let headers = ['title1', 'title2', 'title3'];

let obj = {
    0: ['name1', 'name2', 'name3'],
    1: ['example1', 'example2', 'example3'],
    2: ['xx', 'yy', 'zz']
};

let result = Object.fromEntries(Object.values(obj).map((v,i) => ([headers[i], v])));
console.log(result);


1
投票

在你的例子中,你不是在改变你的对象,而是在改变

Object.keys
返回给你的一组键,这是没有意义的。具体方法如下:

const headers = ['title1', 'title2', 'title3']

const obj = {
    0: ['name1', 'name2', 'name3'],
    1: ['example1', 'example2', 'example3'],
    2: ['xx', 'yy', 'zz'],
}

const renameObj = (obj, keys) => {
  return keys.reduce((acc, key, index) => ({ ...acc, [key]: obj[index] }), {})
}

console.log(renameObj(obj, headers))

© www.soinside.com 2019 - 2024. All rights reserved.