function* test(action) {
const subgenerator = function*() {
const subgeneratorVariable = yield '1';
console.log('subgeneratorVariable', subgeneratorVariable);
};
for (const generatedValue of subgenerator()) {
const result = yield generatedValue;
console.log('result', result);
}
}
const gen = test();
console.log(gen.next());
console.log(gen.next('a'));
这将返回:
{value: "1", done: false}
result a
subgeneratorVariable undefined
{value: undefined, done: true}
因此,我无法在嵌套生成器中获得结果。不过!
在这种情况下:
function* test(action) {
const subgenerator = function*() {
const subgeneratorVariable = yield '1';
console.log('subgeneratorVariable', subgeneratorVariable);
const subgeneratorVariable2 = yield '2';
console.log('subgeneratorVariable2', subgeneratorVariable2);
};
const result = yield* subgenerator();
console.log('result', result);
}
const gen = test();
console.log(gen.next());
console.log(gen.next('1'));
console.log(gen.next('2'));
结果是:
{value: "1", done: false}
subgeneratorVariable a
{value: "2", done: false}
subgeneratorVariable2 b
result undefined
{value: undefined, done: true}
所以情况发生了逆转。现在,我只能在嵌套生成器中访问已产生的值。
这两个生成器之间有没有传递值/结果的方法?
发布于 2017-12-19 18:17:50
yield
将作为参数返回要传递给next
的内容,而不是右侧的表达式;for...of
内部调用没有参数的next
,因此获得undefined
。
也许这个例子可以帮助您理解使用do...while
而不是for...of
function* test(action) {
const subgenerator = function*() {
let subgeneratorVariable;
subgeneratorVariable = yield '1';
console.log("subgeneratorVariable: " + subgeneratorVariable);
subgeneratorVariable = yield '2';
console.log("subgeneratorVariable: " + subgeneratorVariable);
};
const sub = subgenerator();
let value;
do {
value = yield sub.next(value).value;
console.log("value: " + value);
} while(value);
}
const gen = test();
let value;
value = gen.next().value;
value = gen.next(value).value;
value = gen.next(value).value;
结果是:
value: 1
subgeneratorVariable: 1
value: 2
subgeneratorVariable: 2
如您所见,如果要在生成器之间保留值,则必须将结果值传递给生成器next
函数。
发布于 2017-12-19 17:59:42
在用javascript中的新yield
进行升级和阅读您的示例之后,我想我知道了您想做什么和做错了什么。
你的第一次尝试是正确的,。但是你把你的console.log
放错了,这让你误以为它是错的。
我重写了它,这样您就可以更好地了解当yield
-ing时发生的事情。
function* generator() {
function* subgenerator() {
yield '1';
yield '2';
};
for (let generatedValue of subgenerator()) {
// Use generatedValue here ...
console.log("Inside generator:",generatedValue);
// .. and finally yield it to your main program
yield generatedValue;
}
}
let gen = generator();
console.log("Outside generator:",gen.next());
console.log("Outside generator:",gen.next());
console.log("Outside generator:",gen.next());
在第二个示例中,将生成委托给子生成器。这样做,就无法获得生成器本身的值。因为这个值是yield
,-ed,并且您的生成器将在子生成器生成完成后恢复。这解释了为什么,您的生成器只看到undefined
。
https://stackoverflow.com/questions/47896833
复制