javascript – JS fügt Objekten mehrere dynamische Eigenschaften hinzu
仅有的幸福
仅有的幸福 2017-06-26 10:51:28
0
5
890
let Obj={};

//给出一个数组
var arr = [
    {a: 'aa'},
    {b: 'bb'},
    {c: 'cc'}
]
//生成如下格式
Obj={
  a:'aa',
  b:'bb',
  c:'cc'
}

Ich persönlich denke, dass Sie Object.assign() zum Zusammenführen verwenden können. Gibt es eine andere gute Methode?

仅有的幸福
仅有的幸福

Antworte allen(5)
小葫芦
arr.reduce((prev, curr) => Object.assign(prev, curr), {})
小葫芦
arr.reduce((prev, next) => {
    Object.keys(next).forEach((item) => {
         prev[item] = next[item]        
    })
    return prev
}, {})
代言

@冴羽 和 @cool_zjy 的方案类似,不过都是产生的一个新对象,按原题意,reduce 的初始值传入 Obj 代替 {} 就好。前者不需要 ES6 特性,后者需要。

@hsfzxjy 的方法看起来固然是简捷了,但是会产生好多中间对象,所以效率应该不会很好。

Object.assign 的方案应该是最简捷了,当然也许 Lodash 库中能找到一个更简单的 API 来实现。

给我你的怀抱

泻药。用 ES6 的 Spread Operator 可以更简洁,不过本质是一样的

let arr = [
    {a: 'aa'},
    {b: 'bb'},
    {c: 'cc'}
]

let obj = arr.reduce((x, y) => ({...x, ...y}), {})
console.log(obj)

洪涛

先自问自答,使用Object.assign()来合并,不知道有没有其他好的方法

Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage