javascript - 最后一项被推送到数组(Javascript)
问题描述
嗨,我的项目中有以下代码。问题是最后一个项目被推送到一个数组而不是每个项目。
JS函数
function getArrayObjForKeys(keys, source, desiredKeys) {
let arrayObj = [],
obj = {};
source.forEach(function(val, ind) {
keys.forEach(function(v, i) {
(function(v) {
if (val.hasOwnProperty(v)) {
let desKey = desiredKeys[i];
obj[desKey] = val[v];
}
}).call(this, v);
});
arrayObj.push(obj);
});
return arrayObj;
}
// Invoking function as below
// **************************
var source = [{
'country': 'USA',
'descr': 'United States'
}, {
'country': 'UK',
'descr': 'United Kingdom'
}];
var countryList = getArrayObjForKeys(['country', 'descr'], source, ['value', 'label']);
console.info(countryList);
期望的输出
[{'value':'USA','label':'United States'},{'value':'UK','label':'United Kingdom'}]
普朗克
https://next.plnkr.co/edit/3SKbaJo9r5QX8hex?open=lib%2Fscript.js
解决方案
您的问题是您obj
在内存中引用相同的内容,因此修改了两个对象。对此的快速解决方法是将您的对象声明移动到foreach
循环中,因此您对每个对象都有自己的唯一引用(不一样)。
请参阅下面的工作示例:
function getArrayObjForKeys(keys, source, desiredKeys) {
let arrayObj = []
source.forEach(function(val, ind) {
let obj = {}; /* Move into foreach */
keys.forEach(function(v, i) {
(function(v) {
if (val.hasOwnProperty(v)) {
let desKey = desiredKeys[i];
obj[desKey] = val[v];
}
}).call(this, v);
});
arrayObj.push(obj);
});
return arrayObj;
}
var source = [{
'country': 'USA',
'descr': 'United States'
}, {
'country': 'UK',
'descr': 'United Kingdom'
}];
var countryList = getArrayObjForKeys(['country', 'descr'], source, ['value', 'label']);
console.info(countryList);
推荐阅读
- python - 如果它们都在移动,如何检测一个矩形是否在另一个矩形中?
- javascript - Node JavaScript express 从 sequlize 查询中获取的 JavaScript 格式数据
- gradle - 找不到参数的方法 annotationProcessor()
- flutter - 有没有办法在颤动中剪辑应用程序栏?
- javascript - 如何防止在购物车中两次添加相同的产品
- c++ - 从多个线程写入内存区域会导致争用吗?
- google-bigquery - BigQuery 中的随机字符串函数
- objective-c - 苹果审查团队会允许在 AppStore 上运行原生应用吗
- javafx - 使用 pdfbox 将表格绘制成 pdf
- c# - 如何使用没有迁移历史的实体框架更新数据库