国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

深入理解ES6之《迭代器與生成器》

myshell / 2218人閱讀

摘要:什么是迭代器中創(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ò)誤

訪問(wèn)默認(rèn)迭代器
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

相關(guān)文章

  • 深入理解ES6迭代器與成器

    摘要:什么是迭代器中創(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...

    王軍 評(píng)論0 收藏0
  • ES6迭代器與迭代對(duì)象

    摘要:通過(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)部原理與使用方法 ...

    terasum 評(píng)論0 收藏0
  • ES6】更易于繼承的類(lèi)語(yǔ)法

    摘要:的類(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 的新特性衍...

    Lionad-Morotar 評(píng)論0 收藏0
  • 數(shù)據(jù)結(jié)構(gòu) - 收藏集 - 掘金

    面試舊敵之紅黑樹(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...

    leeon 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<