嗨,我的项目中有以下代码。问题是最后一个项目被推入数组而不是每个项目。
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);
关于javascript - 最后一项被推送到数组(Javascript),我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/54551408/