es6新特性(五之generator)

本文介绍了JavaScript中生成器(generator)的概念与使用方法,包括如何声明和调用生成器,yield与return的区别,以及与Promise结合使用时如何简化异步操作。随着async/await的出现,生成器的使用已逐渐减少。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

generator (生成器)一个可暂停的方法,配合关键词yield,return,next

  • 一、generator的申明

申明方法时多加一个*,便可以得到一个generator对象,*可放在functtion和方法名之间,但不能紧贴着,一定要留空格

let g=function* Test()
{
    yield //当遇到yield会暂停
}
  • 二、generator的调用

generator不能直接被调用,要使用next()方法调用

let g=function* Test()
{
   let a= yield  ;
   
   alert(a);
}
let res=g().next(123)//next里可以给yield传参,但第一次next是不会从yield身上拿到值的,
//因为在遇到yield就已经暂停,还没有进行赋值操作
  • 三、yield 和return都会返回一个结果对象,其中包括一个value和done

yield 和return如果不主动给值,value默认是undefined,done为bool值,代办是否所有代码已经执行完毕

  • 四、当Promise和Generator配合使用时,可以应用到一些消除异步操作的场景

 如:当用Promise来处理,同时多个异步请求时,如果我们只需要拿数据,不需要其他逻辑时,可以用它来封装异步操作。

但是如果我们的需求是要根据拿到的不同的数据,再做不同的请求操作时,这时候就会非常麻烦,和以往的多层嵌套异步回调就没有多大的差别的,这时候就可以用Promise和Generator配合使用来简化代码操作。

  • 五、但generator现在已经完成被async和await给取代了,因为不再需要外部的runner来辅助。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值