Generator生成器

Generator 對象

普通函數(shù)定義時在 function 關鍵字后面添加 * 即可聲明一個生成器,函數(shù)返回一個可迭代對象,函數(shù)內部通過 yield 關鍵字來指定調用迭代器的 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 進行遍歷

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

注意:使用 for of 遍歷之前如果使用了 next() 調用,則只會遍歷到未被調用的 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 表達式的值,此時 b = 12
console.log(g.next(6))  // {value:3, done:false}

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

Generator函數(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)
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

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

友情鏈接更多精彩內容