Object.assign保持对原始对象的引用

Moh*_*awy 6 javascript babeljs

我有方法:

export const groupActivities = ({ activities, tags, images, tickets }) => {
  if (!activities || !tags) {
    console.error('Must have activities and tags');
  }

  const groupActivities = Object.assign({}, activities);

  const groups = groupByTags({ activities: groupActivities, tags });

  groups.forEach(group => {
    group.length = group.activities.length;
    console.log(group.length);
    group.activities.forEach(activity => {
      if (images) {
        activity.images = activity.imageIds.map(id => images[id]);
      }

      if (tickets) {
        console.warn('No tickets provided to the groupactivities helper. May cause problems.');
        activity.tickets = activity.ticketIds.map(id => tickets[id]);
      }
    });
  });

  return groups;
};
Run Code Online (Sandbox Code Playgroud)

Object.assign正在复制活动对象,但仍保留对其的引用,因此,如果我找到特定的活动并更改了它的某些属性,它也会更改原始对象!(更改groupActivities ['someID']。name ='name'会更改活动对象上的相应活动!)

这导致了一些奇怪的错误。有什么办法吗?

使用babel 5进行编译。

Dhi*_*aTN 4

事实上,这可以通过不同的方式来完成:

  1. 如果您不想外部导入,请实现您自己的,但要考虑嵌套对象。我实现了我自己的如下(如果你有一个嵌套对象,你需要深度克隆,所以设置deep=true):
function cloneObj(obj, deep=false){
  var result = {};
  for(key in obj){
    if(deep && obj[key] instanceof Object){
       if(obj[key] instanceof Array){
         result[key] = [];
         obj[key].forEach(function(item){
            if(item instanceof Object){
               result[key].push(cloneObj(item, true));
            } else {
               result[key].push(item);
            }
         });
       } else {
         result[key] = cloneObj(obj[key]);
       }
    } else {
       result[key] = obj[key];
    }
  }
  return result
}


// Shallow copy
var newObject = cloneObj(oldObject);
// Deep copy
var newObject = cloneObj(oldObject, true);
Run Code Online (Sandbox Code Playgroud)
  1. 使用jQuery
// Shallow copy
var newObject = jQuery.extend({}, oldObject);

// Deep copy
var newObject = jQuery.extend(true, {}, oldObject);
Run Code Online (Sandbox Code Playgroud)
  1. 使用UnderscoreJS
 // Shallow copy
 var newObject = _.clone(oldObject);
Run Code Online (Sandbox Code Playgroud)

PS:我用以下数据测试了我的功能并且工作正常:

var oldObject = {a:1, b:{d:2,c:6}, c:[1,2,{t:1}]};
newObject= cloneObj(oldObject, true);

newObject['b']['d']=8;
newObject['a']=8;
newObject['c'][2]['t']=5;


console.log(oldObject)
console.log(newObject)
Run Code Online (Sandbox Code Playgroud)