遍历javascript对象的集合

时间:2019-02-12 17:18:04

标签: javascript

我试图只读取friends数组的第一个元素,并将其添加到每个对象的matchs数组中。如果我直接在对象上添加matchs属性。然后返回预期结果。但是,如果我使用功能addmatches添加匹配项数组属性。然后,每个动物对象的match数组值都相同。

var AnimalCreator = function(username, species, tagline, noises) {
  var friends = [];
   //var matches = [];
  return {
    username: username,
    species: species,
    tagline: tagline,
    noises: noises,
    friends: friends,
    //matches: matches
  }
};

var sheep = AnimalCreator('Cloud', 'sheep', 'You can count on me!', ['baahhh', 'arrgg', 'chewchewchew']);
var rabbit = AnimalCreator('Sky', 'Rabbit', 'I like jumping!', ['haha', 'heehee']);
var tiger = AnimalCreator('Tim', 'Tiger', 'I am strong!', ['Grrrr', 'grrrrrr!']);
var bear = AnimalCreator('Poo', 'Bear', 'I am your friend', ['wowo', 'whwhwh']);

var addFriend = function(animal, friend) {
  animal.friends.push(friend.username);
};

addFriend(sheep, rabbit);
addFriend(sheep, tiger);
addFriend(tiger, bear);

var myFarm = [sheep, rabbit, tiger, bear];

var addmatches  = function(farm){
  var matches = [];
  for(var i=0;i < farm.length; i++){
    farm[i].matches = matches;
  }
};

addmatches(myFarm);
var giveMatches = function(farm) {
  for (var i = 0; i < farm.length; i++) {
    if (farm[i].friends.length > 0) {
      farm[i].matches.push(farm[i].friends[0]);
    }
  }
};
giveMatches(myFarm);
console.log(myFarm);

2 个答案:

答案 0 :(得分:2)

matches是对空数组的引用,您的代码为每个farm对象(farm[i].matches = matches;)分配了相同的引用,您可以尝试直接分配空数组,例如

farm[i].matches = [];

您的注释代码:函数AnimalCreator在每次调用时创建一个新的数组实例,并且每个animal对象都引用一个唯一的数组,这就是为什么当您直接添加matches,它可以正常工作。

希望这会有所帮助!

答案 1 :(得分:2)

这是因为数组是通过引用传递的,所以每个服务器场对象都通过此“ farm [i] .matches = matchs;”指向同一数组。要解决此问题,您可以进行多次整理。

  1. 更改“ farm [i] .matches =匹配项”;为“ farm [i] .matches = [];” (到目前为止,最好的选择)。
  2. 移动“无匹配项= [];”在for循环内部,并使用由“ var”插入的“ let”。