generator总结(异步编程、yield、next()、await 、async)

提示:Generator 是一个迭代器生成函数,其返回值是一个迭代器(Iterator),可用于异步调用。
迭代器协议: 定义了一种标准的方式来产生一个有限或无限序列的值

Generator 函数的定义

  • 语法上,可以把理解成,Generator 函数是一个状态机,封装了多个内部状态。
  • 形式上,Generator 函数是一个普通函数。它不同于普通函数,是可以暂停执行的,所以函数名之前要加星号,以示区别。
  • 整个Generator函数就是一个封装的异步任务,或者说是异步任务的容器,异步操作需要暂停的地方,都用yield语句。

Generator 是什么?

Generator 函数是 ES6 提供的一种异步编程解决方案,语法行为与传统函数完全不同。

Generator基本用法?

他跟普通函数就是多一个  *  号

一般和yield联合使用

调用generator函数会返回一个generator对象,

要执行yield 需要调用generator对象的next(函数)

对象返回两个参数value 和 done

Generator 函数是分段执行的,yield表达式是暂停执行的标记,而next方法可以恢复执行。

如下案例:

function* gen(x){
    
    //一个 Generator 函数
	console.log('x='+x)
	var y = yield x + 2;
    
	return y;
}
//调用Generator 函数
var g = gen(1);
 
g.next();
输出:x=1
{
    
    value: 3, done: false}
 
注意:调用g.next() 即执行异步任务的  x+2  
  • next 方法的作用是分阶段执行 Generator 函数。每次调用 next 方法,会返回一个对象,表示当前阶段的信息( value 属性和 done 属性)。
  • value 属性是 yield 语句后面表达式的值,表示当前阶段的值;
  • done 属性是一个布尔值,表示 Generator 函数是否执行完毕,即是否还有下一个阶段(done为false 继续执行)。

使用场景:

通过yield标识位和next()方法调用,实现函数的分段执行

场景模拟:做异步操作

猜你喜欢

转载自blog.csdn.net/zzDAYTOY/article/details/108432751