我试图只读取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);
答案 0 :(得分:2)
matches
是对空数组的引用,您的代码为每个farm
对象(farm[i].matches = matches;
)分配了相同的引用,您可以尝试直接分配空数组,例如
farm[i].matches = [];
您的注释代码:函数AnimalCreator
在每次调用时创建一个新的数组实例,并且每个animal
对象都引用一个唯一的数组,这就是为什么当您直接添加matches
,它可以正常工作。
希望这会有所帮助!
答案 1 :(得分:2)
这是因为数组是通过引用传递的,所以每个服务器场对象都通过此“ farm [i] .matches = matchs;”指向同一数组。要解决此问题,您可以进行多次整理。