国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

js中Generator函數的深入講解

2019-11-19 11:52:05
字體:
來源:轉載
供稿:網友

前言

Generator函數是es6提供的一種異步編程的解決方案,語法行為與傳統(tǒng)函數完全不一樣。

Generator函數有多種理解角度,從語法上,首先可以把它理解成,Generator函數是一個狀態(tài)機,封裝了多個內部狀態(tài)。
執(zhí)

行Generator函數會返回一個遍歷器對象,也就是說,Generator函數除了是狀態(tài)機還是一個遍歷器對象生成函數。 返回遍歷器對象,可以依次遍歷Generator函數內部的每一個狀態(tài)。

下面話不多說了,來一起看看詳細的介紹吧

語法上

首先可以把它理解成,Generator 函數是一個狀態(tài)機,封裝了多個內部狀態(tài)。執(zhí)行 Generator 函數會返回一個遍歷器對象,也就是說,Generator 函數除了狀態(tài)機,還是一個遍歷器對象生成函數。返回的遍歷器對象,可以依次遍歷 Generator 函數內部的每一個狀態(tài)。

形式上

Generator 函數是一個普通函數,但是有兩個特征。

 一是,function關鍵字與函數名之間有一個星號;
 二是,函數體內部使用yield表達式,定義不同的內部狀態(tài)(yield在英語里的意思就是“產出”)。

調用上

Generator 函數的調用方法與普通函數一樣,也是在函數名后面加上一對圓括號。不同的是,調用 Generator 函數后,該函數并不執(zhí)行,返回的也不是函數運行結果,而是一個指向內部狀態(tài)的指針對象,也就是上一章介紹的遍歷器對象(Iterator Object)。我們必須調用遍歷器對象的next方法,使得指針移向下一個狀態(tài)。也就是說,每次調用next方法,內部指針就從函數頭部或上一次停下來的地方開始執(zhí)行,直到遇到下一個yield表達式(或return語句)為止。換言之,Generator 函數是分段執(zhí)行的,yield表達式是暫停執(zhí)行的標記,而next方法可以恢復執(zhí)行

function* helloWorldGenerator() { yield 'hello'; yield 'world'; return 'ending';}var hw = helloWorldGenerator();hw.next()// { value: 'hello', done: false }hw.next()// { value: 'world', done: false }hw.next()// { value: 'ending', done: true }hw.next()// { value: undefined, done: true }

調用 Generator 函數,返回一個遍歷器對象,代表 Generator 函數的內部指針。以后,每次調用遍歷器對象的next方法,就會返回一個有著value和done兩個屬性的對象。value屬性表示當前的內部狀態(tài)的值,是yield表達式后面那個表達式的值;done屬性是一個布爾值,表示是否遍歷結束。

yield表達式

yield表達式與return語句既有相似之處,也有區(qū)別。相似之處在于,都能返回緊跟在語句后面的那個表達式的值。區(qū)別在于每次遇到y(tǒng)ield,函數暫停執(zhí)行,下一次再從該位置繼續(xù)向后執(zhí)行,而return語句不具備位置記憶的功能。一個函數里面,只能執(zhí)行一次(或者說一個)return語句,但是可以執(zhí)行多次(或者說多個)yield表達式。正常函數只能返回一個值,因為只能執(zhí)行一次return;Generator 函數可以返回一系列的值,因為可以有任意多個yield。從另一個角度看,也可以說 Generator 生成了一系列的值,這也就是它的名稱的來歷(英語中,generator 這個詞是“生成器”的意思)。

語法注意點:

1.yield表達式只能用在 Generator 函數里面

2.yield表達式如果用在另一個表達式之中,必須放在圓括號里面

3.yield表達式用作函數參數或放在賦值表達式的右邊,可以不加括號。

例如:

function* demo() { foo(yield 'a', yield 'b'); // OK let input = yield; // OK}

next 方法的參數

yield表達式本身沒有返回值(就是說let a=yield ;會返回undefined),或者說總是返回undefined。next方法可以帶一個參數,該參數就會被當作上一個yield表達式的返回值 (注意,是表達式的返回值,例如 let a=yield.......... 參數會是a 的值并且會覆蓋表達式之前的值)。

function* f() { for(var i = 0; true; i++) { var reset = yield i; console.log(reset); if(reset) { i = -1; } }}var g = f();g.next() 

由于next方法的參數表示上一個yield表達式的返回值,所以在第一次使用next方法時,傳遞參數是無效的。V8 引擎直接忽略第一次使用next方法時的參數,只有從第二次使用next方法開始,參數才是有效的。從語義上講,第一個next方法用來啟動遍歷器對象,所以不用帶有參數。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對武林網的支持。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 台南县| 洪江市| 新余市| 丰原市| 蓝田县| 白山市| 玛多县| 肥东县| 洛隆县| 共和县| 韩城市| 阿巴嘎旗| 梁山县| 随州市| 和田市| 孟连| 灌阳县| 龙门县| 奎屯市| 洛隆县| 威宁| 金华市| 桃园县| 乐平市| 汕头市| 类乌齐县| 舞阳县| 崇州市| 咸阳市| 毕节市| 忻城县| 赣州市| 太谷县| 卓资县| 安新县| 陆丰市| 电白县| 金阳县| 陆丰市| 汤阴县| 富宁县|