function foo(x,y) {
return request(
//request是一个Promise对象
"http://some.url.1/?x=" + x + "&y=" + y
);
}
function *main() {
try{
var text = yield foo( 11, 31 );
//在yield处暂停后 yield需要等待第二次next()传值 text应该没有被赋值
console.log( text );
}
catch (err) {
console.error( err );
}
}
var it = main();
var p = it.next().value;
//等待promise p决议
p.then(
function (text) {
it.next( text );
//这里拿到的 text 应该没有赋到值呀
},
function (err) {
it.throw( err );
}
);
这是你不知道的JavaScript 生成器+Promise 小节中的一段示例代码
**其中 text 应该拿到的是yield 的值 而yield 应该需要第二个next()去赋值 那么 text应该是undefined 这里我就看不懂了 求解!**
Le prochain appel du premier itérateur sera exécuté au premier rendement. À ce moment, aucune valeur n'est attribuée, mais une fonction ajax basée sur la promesse est renvoyée.
.Après la résolution de cette promesse, la valeur de retour de la requête ajax sera. être utilisé comme paramètre Le formulaire est affecté à la première fonction puis comme paramètre
comme ceci
Ensuite, ce paramètre sera affecté à la position du premier rendement et la fonction sera exécutée
J'ai mal compris, le texte est le résultat d'une demande réussie, je vous suggère de comprendre à nouveau Promise