摘要:什么是迭代器中創(chuàng)建迭代器如下所示什么是生成器生成器是一種返回迭代器的函數(shù)每當(dāng)招待完一條語(yǔ)句后函數(shù)就會(huì)自動(dòng)停止執(zhí)行關(guān)鍵字可返回任何值或表達(dá)式關(guān)鍵字只可在生成器內(nèi)部使用,在其它地方使用會(huì)導(dǎo)致程序拋出語(yǔ)法錯(cuò)誤所以下面例子是有錯(cuò)誤的可迭代對(duì)象具有屬
什么是迭代器
ES5中創(chuàng)建迭代器如下所示:
function createIterator(items) { var i = 0 return { next: function () { var done = i >= items.length var value = !done ? items[i++] : undefined return { done: done, value: value } } } } var iterator = createIterator([1, 2, 3]) console.log(iterator.next())什么是生成器
生成器是一種返回迭代器的函數(shù)
每當(dāng)招待完一條yield語(yǔ)句后函數(shù)就會(huì)自動(dòng)停止執(zhí)行
function *createIterator(){ yield 1 yield 2 yield 3 } let iterator =createIterator() console.log(iterator.next())
yield關(guān)鍵字可返回任何值或表達(dá)式
function* createIterator(items) { for (let i = 0; i < items.length; i++) { yield items[i] } } let iterator = createIterator([1, 2, 3]) console.log(iterator.next())
yield關(guān)鍵字只可在生成器內(nèi)部使用,在其它地方使用會(huì)導(dǎo)致程序拋出語(yǔ)法錯(cuò)誤
所以下面例子是有錯(cuò)誤的
function* createIterator(items) { items.forEach(function (element) { yield itemsm + 1 }); } let iterator = createIterator([1, 2, 3]) console.log(iterator.next())
可迭代對(duì)象具有Symbol.iterator屬性,可通過(guò)Symbol.iterator指定的函數(shù)來(lái)作用于一個(gè)附屬對(duì)象的迭代器
由于生成器默認(rèn)會(huì)有Symbol.iterator屬性賦值,因此所有通過(guò)生成器創(chuàng)建的迭代器都是可迭代對(duì)象
如果將for of 語(yǔ)句用于不可迭代對(duì)象、null或undefined將會(huì)導(dǎo)致程序拋出錯(cuò)誤
let values = [1, 2, 3] let iterator = values[Symbol.iterator]() console.log(iterator.next())
檢測(cè)一個(gè)對(duì)象是否為可迭代對(duì)象
function isIterable(obj) { return typeof obj[Symbol.iterator] === "function" } console.log(isIterable([1, 2, 3]))創(chuàng)建可迭代對(duì)象
let collection = { items: [], *[Symbol.iterator]() { for (let item of this.items) { yield item } } } collection.items.push(1) collection.items.push(2) collection.items.push(3) for (let x of collection) { console.log(x) }內(nèi)建迭代器
數(shù)組、Map集合、Set集合,這3個(gè)對(duì)象都內(nèi)建了以下三種迭代器
keys
values
entries
每個(gè)集合對(duì)象都有一個(gè)默認(rèn)的迭代器,在for of循環(huán)中,如果沒(méi)有顯式指定則使用默認(rèn)迭代器
數(shù)組和set集合默認(rèn)的迭代器是values
Map集合默認(rèn)的迭代器是entries
let tracking = new Set([123, 456, 789]) //與調(diào)用tracking.values方法相同 for (let num of tracking) { console.log(num) }
不僅僅字符串可以用for of來(lái)迭代,NodeList也可以
let divs = document.getElementsByTagName("div") for (let div of divs) { console.log(div) }
展開(kāi)運(yùn)算符可作用于任何可迭代對(duì)象
let one = [1, 2, 3] let two = [100, 101, 102] let all = [0, ...one, ...two] console.log(all)//[0, 1, 2, 3, 100, 101, 102]高級(jí)迭代器
給迭代器傳遞參數(shù)
function* createIterator() { let first = yield 1 let second = yield first + 2//4+2 yield second + 3//5+3 } let iterator = createIterator() console.log(iterator.next()) console.log(iterator.next(4)) console.log(iterator.next(5)) console.log(iterator.next())
在迭代器中拋出錯(cuò)誤
function* createIterator() { let first = yield 1 let second try { second = yield first + 2 } catch (error) { second = 6 } yield second + 3 } let iterator = createIterator() console.log(iterator.next())//{value: 1, done: false} console.log(iterator.next(4)) //{value: 6, done: false} console.log(iterator.throw(new Error("Boom")))//{value: 9, done: false} console.log(iterator.next())//{value: undefined, done: true}
生成器返回語(yǔ)句
function* createIterator() { yield 1 return; yield 2 yield 3 } let iterator = createIterator() console.log(iterator.next())//{value: 1, done: false} console.log(iterator.next())//{value: undefined, done: true}
function* createIterator() { yield 1 return 42 } let iterator = createIterator() console.log(iterator.next())//{value: 1, done: false} console.log(iterator.next())//{value: 42, done: true} console.log(iterator.next())//{value: undefined, done: true}
有一點(diǎn)需要注意的是展開(kāi)運(yùn)算符與for of循環(huán)語(yǔ)句會(huì)直接忽略掉通過(guò)return語(yǔ)句指定的任何返回值,只要done一變?yōu)閠rue就立即停止讀取其它的值
異步任務(wù)執(zhí)行器向任務(wù)執(zhí)行器傳遞參數(shù)
function run(taskDef) { let task = taskDef() let result = task.next() function step() { if (!result.done) { result = task.next(result.value) step() } } step() } run(function* () { let value = yield 1 console.log(value) value = yield value + 3 console.log(value) })
異步任務(wù)執(zhí)行器
function run(taskDef) { //創(chuàng)建一個(gè)無(wú)使用限制的迭代器 let task = taskDef() // 開(kāi)始執(zhí)行任務(wù) let result = task.next() // 循環(huán)調(diào)用next函數(shù) function step() { // 如果任務(wù)未完成則繼續(xù)執(zhí)行 if (!result.done) { if (typeof result.value === "function") { result.value(function (err, data) { if (err) { result = task.throw(err) return; } result = task.next(data) step() }) } else { result = task.next(result.value) step() } } } // 開(kāi)始執(zhí)行迭代任務(wù) step() } let fs = require("fs") function readFile(fileName) { return function (callback) { fs.readFile(fileName, callback) } } run(function* () { let contents = yield readFile("config.json") doSomethingWith(contents) console.log("hello") })
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/112502.html
摘要:什么是迭代器中創(chuàng)建迭代器如下所示什么是生成器生成器是一種返回迭代器的函數(shù)每當(dāng)招待完一條語(yǔ)句后函數(shù)就會(huì)自動(dòng)停止執(zhí)行關(guān)鍵字可返回任何值或表達(dá)式關(guān)鍵字只可在生成器內(nèi)部使用,在其它地方使用會(huì)導(dǎo)致程序拋出語(yǔ)法錯(cuò)誤所以下面例子是有錯(cuò)誤的可迭代對(duì)象具有屬 什么是迭代器 ES5中創(chuàng)建迭代器如下所示: function createIterator(items) { var i = 0 retu...
摘要:通過(guò)生成器創(chuàng)建的迭代器也是可迭代對(duì)象,因?yàn)樯善髂J(rèn)會(huì)為屬性賦值。我們可以用來(lái)訪問(wèn)對(duì)象的默認(rèn)迭代器,例如對(duì)于一個(gè)數(shù)組獲得了數(shù)組這個(gè)可迭代對(duì)象的默認(rèn)迭代器,并操作它遍歷了數(shù)組中的元素。 ES6 新的數(shù)組方法、集合、for-of 循環(huán)、展開(kāi)運(yùn)算符(...)甚至異步編程都依賴于迭代器(Iterator )實(shí)現(xiàn)。本文會(huì)詳解 ES6 的迭代器與生成器,并進(jìn)一步挖掘可迭代對(duì)象的內(nèi)部原理與使用方法 ...
摘要:的類(lèi)使用熟悉的關(guān)鍵字指定類(lèi)繼承的函數(shù),并且可以通過(guò)方法訪問(wèn)父類(lèi)的構(gòu)造函數(shù)。例如繼承一個(gè)的類(lèi)繼承了,術(shù)語(yǔ)上稱為基類(lèi),為派生類(lèi)。例如注意到上例中,不僅是派生類(lèi)的實(shí)例,也是派生類(lèi)的實(shí)例,內(nèi)建對(duì)象繼承的實(shí)用之處是改變返回對(duì)象的類(lèi)型。 和其它面向?qū)ο缶幊陶Z(yǔ)言一樣,ES6 正式定義了 class 類(lèi)以及 extend 繼承語(yǔ)法糖,并且支持靜態(tài)、派生、抽象、迭代、單例等,而且根據(jù) ES6 的新特性衍...
面試舊敵之紅黑樹(shù)(直白介紹深入理解) - Android - 掘金 讀完本文你將了解到: 什么是紅黑樹(shù) 黑色高度 紅黑樹(shù)的 5 個(gè)特性 紅黑樹(shù)的左旋右旋 指定節(jié)點(diǎn) x 的左旋 右圖轉(zhuǎn)成左圖 指定節(jié)點(diǎn) y 的右旋左圖轉(zhuǎn)成右圖 紅黑樹(shù)的平衡插入 二叉查找樹(shù)的插入 插入后調(diào)整紅黑樹(shù)結(jié)構(gòu) 調(diào)整思想 插入染紅后... java 多線程同步以及線程間通信詳解 & 消費(fèi)者生產(chǎn)者模式 & 死鎖 & Thread...
閱讀 1984·2021-11-24 09:38
閱讀 3344·2021-11-22 12:07
閱讀 1912·2021-09-22 16:03
閱讀 1969·2021-09-02 15:41
閱讀 2626·2021-07-24 23:28
閱讀 2219·2019-08-29 13:17
閱讀 1560·2019-08-29 12:25
閱讀 2674·2019-08-29 11:10