gpt4 book ai didi

javascript - 从 Javascript 中的对象中引用对象的数组

转载 作者:行者123 更新时间:2023-11-29 17:53:24 25 4
gpt4 key购买 nike

我想创建一个 InvertedPeninsula 类型的新对象:

var invertedPeninsula = new InvertedPeninsula();

为了创建这个对象类型,我使用了一个对象构造函数:

var InvertedPeninsula = function() {
this.inhabitants = [
{
name: 'Flanery',
race: 'Human'
},
{
name: 'Sir Charles',
race: 'Human'
},
{
name: 'Ealei',
race: 'Elf'
},
{
name: 'Orado',
race: 'Spector'
}
];

this.inhabitants.getRace = function(race) {
var members = [];
for (var i=0, l = this.length; i < l; i++) {
if (this[i].race === race) {
members.push(this[i]);
}
}

return members;
};

this.inhabitants.humans = function() {
return this.getRace('Human');
};

this.inhabitants.elves = function() {
return this.getRace('Elf');
};

this.inhabitants.spectors = function() {
return this.getRace('Spector');
};
};

总而言之,构造函数创建了一个对象,其中包含一个名为“inhabitants”的数组,该数组本身包含 4 个对象字面量。 InvertedPeninsula 对象类型构造函数然后继续向居民数组添加四个函数表达式。换句话说,居民数组包含 4 个对象和 4 个方法,也可以通过使用“for-in”迭代器打印数组的内容来确认。

一切都按照我想要的方式运行,但我想了解的是,到底为什么这个构造函数可以在不提及其名称的情况下引用居民数组而逃脱惩罚。特别是:

for (var i=0, l = this.length; i < l; i++) 

上面的代码不应该是:

for (var i=0, l = this.inhabitants.length; i < l; i++) 

代替?

同理,人类、 Sprite 、幽灵数组属性都返回:

return this.getRace('Human');
return this.getRace('Elf');
return this.getRace('Specter');

分别。然而,它不应该是:

return this.inhabitants.getRace('Human');
return this.inhabitants.getRace('Elf');
return this.inhabitants.getRace('Specter');

我进行了这些建议的更改,但是在尝试调用任何一个函数时,例如:

invertedPeninsula.inhabitants.humans();

我收到这些错误:

Uncaught TypeError: Cannot read property 'getRace' of undefined

Uncaught TypeError: Cannot read property 'length' of undefined

我正在使用谷歌浏览器 55.0.2883.87 m

关于这里发生的事情有什么可能的解释吗?

最佳答案

之所以有效,是因为执行此操作时的上下文:

invertedPeninsula.inhabitants.humans();

...不是invertedPeninsula,而是invertedPeninsula.inhabitants,因此方法中对this的任何引用都是对invertedPeninsula .居民.

另请注意,您在构造函数中只定义了一个属性:inhabitants

您在该构造函数中定义的所有其他方法都不是在 this 上创建的,而是在 this.inhabitants 上创建的,它是 that 数组使用更多方法扩展的对象,而不是正在构造的对象。

关于javascript - 从 Javascript 中的对象中引用对象的数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41304300/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com