考虑在Object.prototype
上定义的这个简单的生成器函数:
Object.prototype.defineProperty(Object.prototype, 'pairs', {
enumerable: false,
* value( ) {
for (const key in this)
yield [ key, this[key] ];
} });
当然,它可以像这样使用:
const object = { goats_teleported: 42 };
for (const [ key, value ] of object.pairs());
但是我想知道是否有任何方法可以将pairs
函数分配给对象原型,因此它将在循环中自动触发for-of
而无需显式调用; 就像这样:
for (const [ key, value ] of object);
有什么想法吗?
将生成器放在Object.prototype[Symbol.iterator]
:
Object.prototype[Symbol.iterator] = function* pairs() {
for (const key in this) yield [ key, this[key] ];
};
const object = { goats_teleported: 42, foo: 'fooval' };
for (const [ k, v ] of object) {
console.log(k, v);
}
Object.prototoype[Symbol.iterator] = function* pairs() {
//...
};
但请注意,这可能会在任何地方引起副作用。这不应该在生产中使用(或者至少,风险自;)(。
在
ES6 中,您可以使用Symbol.iterator
为原型定义自定义迭代器。看这里