--- title: Generator.prototype.next() slug: Web/JavaScript/Reference/Global_Objects/Generator/next tags: - ECMAScript 2015 - Generator - JavaScript - 原型 - 参考 - 方法 - 生成器 translation_of: Web/JavaScript/Reference/Global_Objects/Generator/next ---
next
()
方法返回一个包含属性 done
和 value
的对象。该方法也可以通过接受一个参数用以向生成器传值。
gen.next(value)
value
返回的对象
包含两个属性:
done
(布尔类型)
true
。 在这种情况下,value
可选地指定迭代器的返回值。false
。 这相当于没有完全指定done
属性。value
- 迭代器返回的任意的Javascript值。当 done
的值为 true
时可以忽略该值。next()方法
下面的例子展示了一个简单的生成器, 以及调用 next
后方法的返回值:
function* gen() { yield 1; yield 2; yield 3; } var g = gen(); // "Generator { }" g.next(); // "Object { value: 1, done: false }" g.next(); // "Object { value: 2, done: false }" g.next(); // "Object { value: 3, done: false }" g.next(); // "Object { value: undefined, done: true }"
在此示例中,使用值调用next
。 请注意,第一次调用没有记录任何内容,因为生成器最初没有产生任何结果。
function* gen() {
while(true) {
var value = yield null;
console.log(value);
}
}
var g = gen();
g.next(1);
// "{ value: null, done: false }"
g.next(2);
// 2
// "{ value: null, done: false }"
Specification | Status | Comment |
---|---|---|
{{SpecName('ES6', '#sec-generator.prototype.next', 'Generator.prototype.next')}} | {{Spec2('ES6')}} | 初始定义 |
{{SpecName('ESDraft', '#sec-generator.prototype.next', 'Generator.prototype.next')}} | {{Spec2('ESDraft')}} | 草案 |