色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

Javascript生成器(Generator)的介紹與使用

瀏覽:2日期:2023-06-10 09:59:24
什么是生成器?

生成器是在函數(shù)內(nèi)部運(yùn)行的一些代碼

返回值后,它會(huì)自行暫停,并且—— 調(diào)用程序可以要求取消暫停并返回另一個(gè)值

這種“返回”不是傳統(tǒng)的從函數(shù) return。所以它被賦予了一個(gè)特殊的名稱——yield。

生成器語法因語言而異。Javascript 的生成器語法類似于 PHP,但是區(qū)別也很大,如果你希望它們的作用相同,那么最終你會(huì)感到非常困惑。

在 javascript 中,如果想要使用生成器,則需要:

定義特殊的生成器函數(shù) 調(diào)用該函數(shù)創(chuàng)建一個(gè)生成器對(duì)象 在循環(huán)中使用該生成器對(duì)象,或直接調(diào)用其 next 方法

我們以下面這個(gè)簡(jiǎn)單的程序做為起點(diǎn),并執(zhí)行以下每個(gè)步驟:

// File: sample-program.jsfunction *createGenerator() { for(let i=0;i<20;i++) { yield i }}const generator = createGenerator()console.log(generator.next())console.log(generator.next())

如果運(yùn)行這段代碼,則會(huì)得到以下輸出:

$ node sample-program.js

{ value: 0, done: false }{ value: 1, done: false }

下面我來解釋該程序是如何工作的。

生成器函數(shù)

首先,代碼中存在生成器函數(shù)的定義:

function* createGenerator() { for(let i=0;i<20;i++) { yield i }}

function 后面的 * 告訴 javascript 這是一個(gè)生成器函數(shù)。以下寫法都是生成器函數(shù)的有效定義。

function*createGeneratorfunction* createGeneratorfunction *createGenerator

* 并不是函數(shù)名的一部分。而是 function* 符號(hào)定義了生成器。

調(diào)用生成器函數(shù)

定義了生成器函數(shù)后,我們將其命名為其他名稱的函數(shù)。

// 注意:當(dāng)調(diào)用時(shí),沒有 *。 * 不是函數(shù)名稱的一部分// `function *` 是用于定義生成器函數(shù)的符號(hào)const generator = createGenerator()

但是要記?。篶reateGenerator 函數(shù)沒有返回值。這是因?yàn)樯善骱瘮?shù)沒有傳統(tǒng)的返回值。相反,當(dāng)你直接調(diào)用生成器函數(shù)時(shí),它總是返回實(shí)例化的 Generator 對(duì)象。

這個(gè)生成器對(duì)象具有一個(gè) next 方法。調(diào)用 next 將在生成器函數(shù)內(nèi)部運(yùn)行代碼。

function* createGenerator() { for(let i=0;i<20;i++) { yield i }}

這很重要,足以再次調(diào)用它。直接調(diào)用生成器函數(shù)不會(huì)在生成器函數(shù)中運(yùn)行任何代碼。而是創(chuàng)建一個(gè)生成器對(duì)象。它在生成器對(duì)象上調(diào)用 next,從而調(diào)用生成器函數(shù)中的代碼。

首次在生成器對(duì)象上調(diào)用 next 時(shí),內(nèi)部代碼將會(huì)一直運(yùn)行,直到出現(xiàn) yield 語句。一旦執(zhí)行到 yield,javascript 將會(huì)暫停該代碼的執(zhí)行,而 next 將返回(即給你,或yield)一個(gè)對(duì)象,該對(duì)象包含 yield 行中的值。

當(dāng)你第二次(或第三次、第四次甚至更多次)再調(diào)用 next 時(shí),代碼將會(huì)取消暫停并繼續(xù)運(yùn)行(在上次調(diào)用時(shí)中斷的地方)。變量(例如本例中的 i )將會(huì)保持它的值。當(dāng)代碼到達(dá)另一個(gè) yield 語句時(shí),該函數(shù)會(huì)再次暫停,并返回一個(gè)包含 yield 值的對(duì)象。

這就是為什么我們要調(diào)用兩次 next

console.log(generator.next())console.log(generator.next())

會(huì)得到以下輸出:

{ value: 0, done: false }{ value: 1, done: false }

生成器函數(shù)中的代碼執(zhí)行完畢后,將來對(duì) next 的任何調(diào)用都會(huì)返回一個(gè)對(duì)象,該對(duì)象的值為 undefined 且done 設(shè)置為 true。

{ value: undefined, done: true }生成器和循環(huán)

雖然可以在生成器對(duì)象上手動(dòng)調(diào)用 next,但我們主要是要在循環(huán)中使用??匆幌逻@個(gè)稍作修改的程序。

// File: sample-program.js@highlightsyntax@jscriptfunction *createGenerator() { for(let i=0;i<5;i++) { yield i }}const generator = createGenerator()for(const value of generator) { console.log(value)}

當(dāng)在 for...of 循環(huán)中使用生成器對(duì)象時(shí),每次循環(huán)都會(huì)在生成器對(duì)象上調(diào)用 next,并用產(chǎn)生的值填充變量(上面的 value)。運(yùn)行該程序?qū)?huì)輸出以下內(nèi)容:

$ node sample-program.js01234

在下一篇文章中,我們將更深入地探討 for ... of 循環(huán),并探索怎樣為 javascript 提供一種內(nèi)置方法來循環(huán) javascript 中的任何對(duì)象。

總結(jié)

到此這篇關(guān)于Javascript生成器(Generator)的文章就介紹到這了,更多相關(guān)Javascript生成器(Generator)內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 国产精品一区二区资源 | 精品国产免费第一区二区三区日韩 | 久久久久久亚洲精品中文字幕 | 男人好大好硬好爽免费视频 | 亚洲精品99久久久久久 | 欧美在线黄 | 中文字幕一区二区在线播放 | 国外精品视频在线观看免费 | 国产护士一级毛片高清 | 久久依人| 国产男女乱淫真视频全程播放 | 日韩欧美一中字暮 | 99久久免费精品国产免费高清 | 久久视频精品36线视频在线观看 | 男人好大好硬好爽免费视频 | 国产精品不卡无毒在线观看 | 视频网18免费 | 中国一级特黄大片毛片 | 亚洲色视频在线播放网站 | 成人午夜久久精品 | 99精品高清不卡在线观看 | 日韩一级欧美一级 | 欧美一级特黄aaaaaa在线看片 | 久久国产精品歌舞团 | 成人毛片一区二区三区 | 国产成版人视频网站免费下 | 在线视免费频观看韩国aaa | 国产免费一区二区在线看 | 国产亚洲高清在线精品不卡 | 日韩亚洲欧美一区噜噜噜 | 在线观看毛片网站 | 国产成人免费在线观看 | 加勒比久久综合 | 国产成人www免费人成看片 | 亚洲天堂精品在线观看 | 久久青草网站 | 台湾50部三级 | 男女午夜性爽快免费视频不卡 | 日韩免费高清一级毛片在线 | 2018久久久国产精品 | 欧美乱一级在线观看 |