ES6生成器用法实例分析
本文实例讲述了ES6生成器用法。分享给大家供大家参考,具体如下:
语法
何为生成器?让我们先看看以下代码:
function* quips(name) { yield "hello " + name + "!"; yield "i hope you are enjoying the blog posts"; if (name.startsWith("X")) { yield "it's cool how your name starts with X, " + name; } yield "see you later!"; }
你没有看错,这就是JavaScript代码。是不是和你曾经认识的javascript不太一样。这个函数就叫做生成器函数。生成器函数看起来和普通的函数是不是有点相像呢?
它们的区别如下:
一般的函数以function开头,而生成器函数以function* 开头。
生成器函数中有一个特殊关键字就是yield,作用就是暂停函数。配合next方法来调用可以达到一步一步的执行函数的目的。
我们看看next方法的使用:
> var iter = quips("lf"); [object Generator] > iter.next() { value: "hello lf!", done: false } > iter.next() { value: "i hope you are enjoying the blog posts", done: false } > iter.next() { value: "see you later!", done: false } > iter.next() { value: undefined, done: true }
可以看到,每一次next方法后,生成器函数就执行到下一个yield位置处。
基本的生成器语法就讲完了。
应用
生成器可以用来异步编程,我在之前的文章中有过介绍,可以参考前面一篇《基于javascript的异步编程实例详解》
但是需要注意的是,生成器并不是用来写异步的,这仅仅是一种hack手段而已。
希望本文所述对大家ECMAScript程序设计有所帮助。
相关文章
uniapp踩坑实战之文件查找失败:'uview-ui' at main.js解决办法
这篇文章主要给大家介绍了关于uniapp踩坑实战之文件查找失败:'uview-ui' at main.js的解决办法,文中通过代码介绍的非常详细,需要的朋友可以参考下2023-12-12layui问题之自动滚动二级iframe页面到指定位置的方法
今天小编就为大家分享一篇layui问题之自动滚动二级iframe页面到指定位置的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2019-09-09
最新评论