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 有所启发。

相关推荐
水云桐程序员8 小时前
C++可以写手机应用吗
开发语言·c++·智能手机
测试员周周8 小时前
【AI测试智能体】为什么传统测试方法对智能体失效?
开发语言·人工智能·python·功能测试·测试工具·单元测试·测试用例
kyriewen8 小时前
百度用6%成本碾压硅谷?中国AI把性价比玩明白了
前端·百度·ai编程
kyriewen8 小时前
你还在手动敲命令部署?GitHub Actions 让你 push 即上线,摸鱼时间翻倍
前端·面试·github
RSTJ_16258 小时前
PYTHON+AI LLM DAY THREETY-NINE
开发语言·人工智能·python
赏金术士9 小时前
Kotlin 从入门到进阶 之函数模块(核心基础)(二)
android·开发语言·kotlin
Csvn10 小时前
Pinia 状态管理
前端
不减20斤不改头像10 小时前
手机一句话开发贪吃蛇!TRAE SOLO 移动端 AI 编程实测
前端·后端
xuankuxiaoyao11 小时前
Vue.js实践-组件基础下
前端·javascript·vue.js
小白学大数据11 小时前
JS 混淆加密下的 Python 爬虫解决方案
javascript·爬虫·python