Iterator 函数返回一个对象,它实现了遗留的迭代协议,并且迭代了一个对象的可枚举属性。
语法
Iterator(object, [keyOnly])
参数
object- 要迭代属性的对象。
keyOnly- 如果
keyOnly是真值,Iterator.prototype.next只返回property_name。
描述
返回迭代了object的Iterator 实例。如果keyOnly为假值,则Iterator 实例返回每次迭代而生成的 [property_name, property_value] 数组,否则,如果keyOnly是真值,则它返回每次迭代的 property_name。如果object 是 Iterator 实例或 Generator 实例 ,则它返回 object 自身。
属性
Iterator.prototype[@@iterator]- 返回一个函数,它返回符合迭代协议的迭代对象。
方法
Iterator.prototype.next- 返回
[property_name, property_value]格式或property_name的下一项。 如果没有更多项,抛出StopIteration。
示例
迭代一个对象的属性
var a = {
x: 10,
y: 20,
};
var iter = Iterator(a);
console.log(iter.next()); // ["x", 10]
console.log(iter.next()); // ["y", 20]
console.log(iter.next()); // throws StopIteration
使用遗留的解构for-in迭代对象的属性
var a = {
x: 10,
y: 20,
};
for (var [name, value] in Iterator(a)) {
console.log(name, value); // x 10
// y 20
}
使用for-of迭代
var a = {
x: 10,
y: 20,
};
for (var [name, value] of Iterator(a)) { // @@iterator is used
console.log(name, value); // x 10
// y 20
}
迭代属性名
var a = {
x: 10,
y: 20,
};
for (var name in Iterator(a, true)) {
console.log(name); // x
// y
}
传入 Generator 实例
function* f() {
yield 'a';
yield 'b';
}
var g = f();
console.log(g == Iterator(g)); // true
for (var v in Iterator(g)) {
console.log(v); // a
// b
}
传入 Iterator 实例
var a = {
x: 10,
y: 20,
};
var i = Iterator(a);
console.log(i == Iterator(i)); // true
规范
非标准。不是目前任何标准文档的一部分。
浏览器兼容性
| Feature | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
|---|---|---|---|---|---|
| Basic support | 未实现 | (Yes) | 未实现 | 未实现 | 未实现 |
| Feature | Android | Chrome for Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
|---|---|---|---|---|---|---|
| Basic support | 未实现 | 未实现 | (Yes) | 未实现 | 未实现 | 未实现 |