generator指的是
function* xxx(){
}
是es6里的写法。
function* test() {
console.log('1');
yield 1;
console.log('2');
yield 2;
console.log('3');
}
代码中间插了两行yield,代表什么呢?
这是不是就像,我们调试代码的时候,给插的断点 ?
当然,断点这个比喻,只是表象上比较相像,实质原理还是有非常大差异。
yield就是让后面的generator执行完成后,才继续往下走。
要注意,function后面多了一个星号,这样是表明这个函数将变成一个生成器函数,而不是一个普通函数了。意思就是,test这个函数,将不能被这样执行
test(); 但可以获得一个生成器
var gen = test(); // gen就是一个生成器了 然后,生成器可以通过next()来执行运行
gen.next();
也就是上面说的,让函数继续运行的指令。
简单地总结一下:
由此可以看出,yield是如何将异步非阻塞代码,变成 异步阻塞代码。