本文摘自PHP中文网,作者不言,侵删。
本篇文章给大家带来的内容是关于ES6生成器用法介绍(附示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
概念
生成器是由生成器函数( generator function )运行后得到的,是可迭代的。
1 2 3 4 5 6 7 8 |
|
原理及简单运用
生成器有一个很大的特点,它可以暂停内部代码运行,返回一个值给外部函数。(暂停后不会阻止其他代码运行)当外部调用其 next 方法后,会继续执行剩下的代码,并接受外部传来的一个参数。这个实现主要依赖于关键字 yield 。
yield 关键字使生成器函数执行暂停,yield 关键字后面的表达式的值返回给生成器的调用者。它可以被认为是一个基于生成器的版本的 return 关键字。
1 2 3 4 5 6 7 8 |
|
一个简单的计数器
1 2 3 4 5 6 7 8 9 10 11 |
|
用同步方式写异步代码
以前处理异步 ajax 请求结果,一般采用传递回调函数的方式。一旦遇到多层回调嵌套,代码的可读性会降低,并且调试起来也不方便。有了生成器之后,我们就可以用同步的方式写异步的代码。这听上去非常的有意思。我们的代码将会是这样的
1 2 3 4 |
|
当然,上面的代码并不能得到正确的结果,它只是一个设想。我们正打算用生成器来实现,而且这是可行的。想想生成器有哪些特点:
- 它能暂停,向外部返回值
- 能继续执行剩下的代码,并接受外部传来的参数
这就足够了。有了生成器函数,现在我们重新来设计代码:
1 2 3 4 5 |
|
静下来想一想有哪些关键字,与暂停、继续有关。停下来...继续...停下来...继续...停下来...继续...Don't...Stop...Don't...Stop...Don't...Stop......这两个词就是 yield、next.
1 2 3 4 |
|
当代码遇到 yield 会暂停,这个时候 asyncFun 函数是不会暂停的,会执行,等执行完毕,再调用生成器的 next 方法,并将返回结果作为参数传给 next。由于在生成器函数内部我们拿不到 next,必须借助于全局变量来传递 next。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
|
这样写,运行看上去有些繁重。可以写一个包装函数运行含有异步代码的生成器函数。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
|
演示地址
不过,自从出了 Promise 和 await 之后,更多的是用这个组合,其使用也更简单,范围也更广。
以上就是ES6生成器用法介绍(附示例)的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
html5 canvas绘图之drawimage() 方法的详细介绍(代码示例)
javascript中var,let与const的区别是什么?
更多相关阅读请进入《生成器》频道 >>

Vue.js 设计与实现 基于Vue.js 3 深入解析Vue.js 设计细节
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者