首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何操作属性为不同名称的数组对象,并使用JavaScript或ecmascript-6在单个对象中返回结果

如何操作属性为不同名称的数组对象,并使用JavaScript或ecmascript-6在单个对象中返回结果
EN

Stack Overflow用户
提问于 2022-10-06 10:46:43
回答 2查看 52关注 0票数 0

我有一个请求数据数组,对象如下:

代码语言:javascript
复制
const requestData = [
  {
    name: 'Test1',
    address: 'FL',
  },
  {
    name: 'Test2',
    address: 'AL',
  },
  {
    name: 'Test3',
    address: 'AK',
  },
]; 

我希望根据索引操作对象属性(这意味着如果索引0将name属性更改为USER_NAME,如果索引1表示更改为EMP_NAME),并将其转换为最终对象,如下所示:

代码语言:javascript
复制
const finalResult = {
  USER_NAME: 'Test1',
  USER_ADDRESS: 'FL',
  EMP_NAME: 'Test2',
  EMP_ADDRESS: 'AL',
  CUST_NAME: 'Test3',
  CUST_ADDRESS: 'AK',
};
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2022-10-06 10:52:56

使用减少()和额外的地图数组可以做到这一点。

代码语言:javascript
复制
let data = [{
    name: 'Test1',
    address: 'FL',
  },
  {
    name: 'Test2',
    address: 'AL',
  },
  {
    name: 'Test3',
    address: 'AK',
  },
]

let mdata =['USER_','EMP_','CUST_']

let result = data.reduce((a,v,i) =>{
  let key = mdata[i]
  a[key+'NAME'] = v.name
  a[key+'ADDRESS'] = v.address
  return a
},{})

console.log(result)

票数 3
EN

Stack Overflow用户

发布于 2022-10-06 10:57:33

您可以构造并构造您的最终结果:

代码语言:javascript
复制
const [ user, emp, cust ] = requestData;

const finalResult = {
    USER_NAME: user.name,
    USER_ADDRESS: user.address,
    EMP_NAME: emp.name,
    EMP_ADDRESS: emp.address,
    CUST_NAME: cust.name,
    CUST_ADDRESS: cust.address
};

或者,您可以减少,但是代码最终会比这个特定示例所需的复杂一些:

代码语言:javascript
复制
const keys = [ "USER", "EMP", "CUST" ];

const finalResult = requestData.reduce(( out, { name, address }, index ) => {
    out[ `${ keys[ index ] }_NAME` ] = name;
    out[ `${ keys[ index ] }_ADDRESS` ] = address;
    return out;
}, {});
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73972545

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档