generator函数详解

Generator函数是ES6引入的新数据类型,可以暂停执行并封装异步任务。它们用星号标识,yield表达式用于暂停和恢复执行。Generator通过next方法分阶段执行,返回包含value和done属性的对象。它们常用于处理异步操作,如Ajax请求和文件读取,简化了回调函数和Promise的使用。Generator与async/await一起,代表了JavaScript异步编程的发展历程。
摘要由CSDN通过智能技术生成

一、Generator

generator(生成器)是ES6标准引入的新的数据类型。一个generator看上去像一个函数,但可以返回多次。

二、Generator 函数的定义

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

三、什么是Generator函数

1、function 关键字和函数之间有一个星号(*),且内部使用yield表达式,定义不同的内部状态。
2、调用Generator函数后,该函数并不执行,返回的也不是函数运行结果,而是一个指向内部状态的指针对象。

function fn(){
    // 定义一个Generator函数
yield ‘hello’;
yield ‘world’;
return ‘end’;
}
var f1 =fn(); // 调用Generator函数
console.log(f1); // fn {[[GeneratorStatus]]: “suspended”}
console.log(f1.next()); // {value: “hello”, done: false}
console.log(f1.next()); // {value: “world”, done: false}
console.log(f1.next()); // {value: “end”, done: true}
console.log(f1.next()); // {value: undefined, done: true}

但是,调用Generator函数后,函数并不执行,返回的也不是函数执行后的结果,而是一个指向内部状态的指针对象。

下一步,必须调用遍历器对象的next方法,使得指针移向下一个状态。即:每次调用next方法,内部指针就从函数头部或上一次停下来的地方开始执行,直到遇到下一个yield表达式(或return语句)为止。

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 继续执行)。

四、Generator 函数的数据交换

function* gen(x){
   
  var y = yield x + 2;
  return y;
}
 
var g = 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值