首页 > 解决方案 > 如何遍历原型“类”JS的实例

问题描述

我想要一个“for”或“while”循环来遍历原型/“类”中的所有实例/对象。像数组中的“hasNext()”。

然后我想实现一个功能。例如 alertname("obj") 这将返回 obj 的名称。问题是我不知道具体的 obj。该函数只获取一个字符串,然后它将在原型中搜索哪个是正确的。

   function Product(id, name) {
    this.id = id;
    this.name = name;
}

Product.prototype.getid = function() {
    i = this.id;
    return i;
};
Product.prototype.getname = function() {
    i = this.name;
    return i;
};

balloon = new Product(0, "Balloon");
var text = "balloon";

//doesnt work
function getname(obj) {
    i = Product.prototype.getname(obj);
    window.alert(i);
}
getname(text);

标签: javascriptprototypejavascript-objects

解决方案


看起来您想要跟踪您创建的所有对象new Product。这是你需要自己实现的东西。

只需创建一个数组:

const stock = [];
stock.push(new Product(0, "Balloon"));
// ...
stock.push(new Product(0, "Monopoly"));

然后你可以简单地迭代它们:

for (const product of stock) {
    console.log(product.getname());
}

JS 没有为您提供这样一个开箱即用的数组是有充分理由的:如果这样做了,那么任何创建的对象都不会被垃圾收集;它们将始终被视为您仍然需要使用的东西。因此,没有内置机制是一件好事。

关于你自己的尝试

Product.prototype.getname(obj);

这没有意义:getname不接受争论。您通常调用原型函数,如方法:

obj.getname()

在某些情况下,您会想要使用,但这仅在不是 的实例Product.prototype.getname时才需要,但非常相似以至于可以调用它。在这种情况下使用:objProductgetname.call()

Product.prototype.getname.call(obj);

推荐阅读