Generator生成器

Generator 對象

普通函數(shù)定義時在 function 關(guān)鍵字后面添加 * 即可聲明一個生成器,函數(shù)返回一個可迭代對象,函數(shù)內(nèi)部通過 yield 關(guān)鍵字來指定調(diào)用迭代器的 next() 方法時的返回值及返回順序

function* test() {
    yield 'a'
    yield 'b'
    yield 'c'
}
const g = test()
g           //   test {<suspended>}
g.next()    //  {value: 'a', done: false}
g.next()    //  {value: 'b', done: false}
g.next()    //  {value: 'c', done: false}
g.next()    //  {value: undefined, done: true}

生成器函數(shù)返回的生成器對象含有 Symbol.Interator 屬性,可以使用 for of 進(jìn)行遍歷

for(value of g) {
  console.log(value)
}
//  a
//  b
//  c

注意:使用 for of 遍歷之前如果使用了 next() 調(diào)用,則只會遍歷到未被調(diào)用的 yield 后的值

g.next()    //  {value: 'a', done: false}
for(value of g) {
  console.log(value)
}
//  b
//  c

next 傳參

使用 next() 時可以通過傳入?yún)?shù)來改變 yield 的返回值,如下

function* gen(a) {
    const b = 2 * (yield(a - 1))
    const c = yield(b / 4)
    return (a + b + c)
}
// a = 2
const g = gen(2)
console.log(g.next())   // {value:1, done:false}

// next(6)傳入的值為 yield 表達(dá)式的值,此時 b = 12
console.log(g.next(6))  // {value:3, done:false}

// next(3)傳入的值為 yield 表達(dá)式的值,此時 c = 3
console.log(g.next(3))  // {value:17, done:true}

Generator函數(shù)嵌套

要求使用生成器函數(shù)改造以下代碼,實(shí)現(xiàn)每隔一秒按順序輸出 1,2,3,4,5

for(let i = 0; i <= 5; i++) {
    setTimeout(() => {
        console.log(i)
    },1000)
}

改寫如下

const delay = n => new Promise(resolve => {
    setTimeout(() => {
        resolve(n)
    },1000)
})
function* g() {
    for(let i = 1; i <= 5; i++) {
        const x = yield delay(i)
        console.log(x)
    }
}
function co(g) {
    const o = g()
    next()
    function next(a) {
        const {value, done} = o.next(a)
        if(done) return
        value.then(data => next(data))
    }
}
co(g)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 在 ES6 標(biāo)準(zhǔn)中,提供了 Generator 函數(shù)(即“生成器函數(shù)”),它是一種異步編程的解決方案。在前面一篇文...
    越前君閱讀 2,508評論 0 7
  • 生成器的核心是一個yield關(guān)鍵字,一個生成器函數(shù)看起來像一個普通的函數(shù),不同的是:普通函數(shù)返回一個值,而一個生成...
    奮斗live閱讀 5,072評論 2 3
  • Generator 函數(shù)的語法 簡介 基本概念 Generator 函數(shù)是 ES6 提供的一種異步編程解決方案,語...
    站在大神的肩膀上看世界閱讀 4,312評論 0 6
  • 1.含義 ??Generator 和普通函數(shù)不同,可以將它看成是封裝了很多狀態(tài)的函數(shù),每執(zhí)行一次該函數(shù),就會返回一...
    外星人_863d閱讀 557評論 1 8
  • 初遇 生成器函數(shù),顧名思義,生成對象,生成一個遍歷器。 generator()為生成器函數(shù),在function和函...
    ByteJitter閱讀 210評論 0 1

友情鏈接更多精彩內(nèi)容