亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

ES6生成器用法實(shí)例分析

 更新時(shí)間:2017年04月10日 09:39:36   作者:布瑞澤的童話  
這篇文章主要介紹了ES6生成器用法,結(jié)合實(shí)例形式分析了ECMAScript6中生成器的概念、語(yǔ)法、使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了ES6生成器用法。分享給大家供大家參考,具體如下:

語(yǔ)法

何為生成器?讓我們先看看以下代碼:

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!";
}

你沒(méi)有看錯(cuò),這就是JavaScript代碼。是不是和你曾經(jīng)認(rèn)識(shí)的javascript不太一樣。這個(gè)函數(shù)就叫做生成器函數(shù)。生成器函數(shù)看起來(lái)和普通的函數(shù)是不是有點(diǎn)相像呢?

它們的區(qū)別如下:

一般的函數(shù)以function開(kāi)頭,而生成器函數(shù)以function* 開(kāi)頭。

生成器函數(shù)中有一個(gè)特殊關(guān)鍵字就是yield,作用就是暫停函數(shù)。配合next方法來(lái)調(diào)用可以達(dá)到一步一步的執(zhí)行函數(shù)的目的

我們看看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方法后,生成器函數(shù)就執(zhí)行到下一個(gè)yield位置處。

基本的生成器語(yǔ)法就講完了。

應(yīng)用

生成器可以用來(lái)異步編程,我在之前的文章中有過(guò)介紹,可以參考前面一篇《基于javascript的異步編程實(shí)例詳解

但是需要注意的是,生成器并不是用來(lái)寫(xiě)異步的,這僅僅是一種hack手段而已。

希望本文所述對(duì)大家ECMAScript程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論