Generator异步解决方案详解

一:三种常见的异步解决方案

  • Promise:链式编程
  • async:使用 async 去修饰函数,然后使用 await 去等待成功
  • Generator:使用 * 修饰函数,然后使用 yield 去等待成功

通俗来讲,Generator 类似于 Promise 到 async 的过渡态。其既可以链式编程,也有 * 修饰符与 yield 暂停等待。当然在项目开发中还是 async 更为常用与便捷。

二:Generator核心语法

Generator 对象由生成器函数返回并且它符合可迭代协议和迭代器协议

生成器函数在执行时能暂停,后面又能从暂停处继续执行

上面的介绍也就是说,Generator 对象不能使用 new 来生成,而是需要使用生成器函数来返回。

基本思路

  • 定义生成器函数
  • 获取 Generator 对象
  • next 方法启动
  • for of 遍历

在下面的代码中,我们定义了一个 GeneratorFunc 生成器函数,而后通过这个生成器函数定义了 g 对象,最后遍历我们可以通过 for of 来实现,同样的也可以注释掉这几行使用下面的 g.next() 来实现遍历功能。

html 复制代码
    <script>
        // 1. 定义生成器函数
        function* GeneratorFunc(){
            yield 'one'
            yield 'two'
            yield 'three'
        }
        // 2. 获取Generator对象
        const g = GeneratorFunc()
        // 3. next 执行
        // { value:'yield',done:false/true}  done:是否执行完毕,为true表示执行完毕,后面没有值
        for(const iterator of g){
            console.log(iterator);
        }
        // 或者是使用next()
        // g.next()
    </script>

三:Generator管理异步

核心步骤,异步操作前加上 yield

在下方代码中,其实和第二点的代码是很类似的,只是将接口写进了生成器函数中,并且在这部分补全了使用 next() 方法获取全部的接口。

其实从下面的代码中可以看到,其代码是和 Promise 很类似的,并且阅读起来没有那么可观,因此才会延伸出来 async 。

html 复制代码
<body>
    <h2>Generator管理异步</h2>
    <script src="https://cdn.bootcdn.net/ajax/libs/axios/1.3.6/axios.js"></script>
    <script>
        // 1. 定义生成器函数
        function* GeneratorFunc(){
            yield axios('http://hmajax.itheima.net/api/city?pname=北京')
            yield axios('http://hmajax.itheima.net/api/city?pname=广东省')
        }
        // 2. 获取Generator对象
        const city = GeneratorFunc()
        // 3. next 执行
        // 或者是使用next()
        city.next().value.then(res => {
            console.log('res:', res);
            return city.next().value
        }).then(res=>{
            console.log('res:', res);
        })
    </script>
</body>

四:总结

Generator 这个知识点是比较琐碎且简单的,因为可以看成 promise 和 async 的过渡,所以其实在实际的项目开发中并没有过多的使用,本来是不打算单独写一篇文章的,不过秉持着努力写好每个知识点的原则,还是将这篇文章写了出来,希望能够对各位小伙伴有所帮助哦。而且掌握这个知识点,能够对你更好的理解 async 有所启发。

相关推荐
WebDesign_Mu3 分钟前
HTML+CSS+JS制作中国传统节日主题网站(内附源码,含5个页面)
javascript·css·html
曦月合一5 分钟前
java中日期如何比大小
java·开发语言·后端
A雄7 分钟前
2025新春烟花代码(二)HTML5实现孔明灯和烟花效果
前端·javascript·html
初学者丶一起加油12 分钟前
C语言基础:野指针、空指针、空悬指针
java·linux·c语言·开发语言·数据结构·算法·vim
L_090712 分钟前
【C】编译与链接
c语言·开发语言
ZWZhangYu15 分钟前
【Arthas命令实践】heapdump实现原理
java·开发语言·python
uhakadotcom20 分钟前
YC:2025年不容错过的1000个硬科技、新质生产力的创新方向清单
前端·面试·github
咔咔库奇21 分钟前
ES6的高阶语法特性
前端·ecmascript·es6
一点一木22 分钟前
Can I Use 实战指南:优化你的前端开发流程
前端·javascript·css
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.23 分钟前
HTML前端从零开始
前端·html