作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我有 2 个数组
(总是等于 index
):
A: [
{name: Jhon1}
{name: Jhon2}
{name: Jhon3}
]
B: [
{lastName: Pom1}
{lastName: Pom2}
{lastName: Pom3}
]
合并后的预期结果:
A: [
{name: Jhon1, lastName: Pom1}
{name: Jhon2, lastName: Pom2}
{name: Jhon3, lastName: Pom3}
]
Concat
方法只是将整个数组合并成一个这样的:
A: [
{name: Jhon1}
{name: Jhon2}
{name: Jhon3}
{lastName: Pom1}
{lastName: Pom2}
{lastName: Pom3}
]
我正在尝试的我自己的功能。下面有两个数组:this.prices
和 this.search.favoriteItems
,我想按照之前描述的方式合并:
showProducts(){
for(let i of this.localStorageArray){
let id = localStorage.getItem(i);
this.search.getProductsById(id).subscribe
((data: any) => {
this.prices.push(data.lowestPrices.Amazon);
this.search.favoriteItems.push(data);
//something here to merge this.prices and this.search
});
}
}
最佳答案
您可以将 .map()
与对象解构结合使用:
let arr1 = [{name: 'Jhon1'}, {name: 'Jhon2'}, {name: 'Jhon3'}],
arr2 = [{lastName: 'Pom1'}, {lastName: 'Pom2'}, {lastName: 'Pom3'}];
let zip = (a1, a2) => a1.map((o, i) => ({...o, ...a2[i]}));
console.log(zip(arr1, arr2));
.as-console-wrapper { max-height: 100% !important; top: 0; }
关于javascript - Angular 2如何将对象数组放入另一个对象数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53632682/
我是一名优秀的程序员,十分优秀!