[英].push() multiple objects into JavaScript array returns 'undefined'
当我向beats数组添加项目然后console.log用户时,我在数组中获得了正确数量的项目。 但是当我检查.length时,我总是得到1.尝试调用索引总是会给我'undefined',就像这样: Tom.beats[1]
我想我错过了一些明显的东西,但这是打败了我。 我怀疑我滥用.push
方法,但我不确定。 任何帮助是极大的赞赏! (使用Chrome开发工具)
//The USER
function User(name, role){
this.beats = [ ];
this.name = name;
this.role = role;
// add beats to beats array
this.addBeats = function(beats){
return this.beats.push(beats);
};
}
// Three New Instances. Three New Users.
var Mal = new User("Mal", "Rapper");
Mal.addBeats(["love", "cash"]);
var Dan = new User("Dan", "Producer");
Dan.addBeats(["cake", "dirt", "sally-mae"]);
var Tom = new User("Tom", "Producer");
Tom.addBeats(["Fun", "Little", "Samsung", "Turtle", "PC"]);
// Check for position in beats array
console.log(Tom.beats);
console.log(Mal.beats);
console.log(Dan.beats);
console.log(Mal.beats[1]);
console.log(Dan.beats[1]);
console.log(Tom.beats[1]);
Array.push(...)
将多个参数附加到列表中。 如果你把它们放在一个数组中,那么这个“beats”数组就会被追加。
Array.concat(...)
很可能不是你想要的,因为它生成一个新数组而不是附加到现有数组。
您可以使用[].push.apply(Array, arg_list)
追加参数列表的项目:
this.addBeats = function(beats) {
return [].push.apply(this.beats, beats);
};
在支持传播运算符的环境中,您现在可以执行以下操作:
this.addBeats = function (beats) {
return this.beats.push(...beats);
};
或者如果你需要更多的控制来覆盖等
this.addBeats = function(beats) {
return this.beats.splice(this.beats.length, null, ...beats);
};
addBeats()应该使用beats参数连接this.beats。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.