嗨,我的项目中有以下代码。问题是最后一个项目被推入数组而不是每个项目。

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/

10-11 12:37
查看更多