品易云推流 关闭
文章详情页
文章 > JavaScript > javascript中throw和next方法的比较

javascript中throw和next方法的比较

javascript throw next

头像

小妮浅浅

2021-09-01 11:59:35844浏览 · 0收藏 · 0评论

1、生成器有throw方法,该方法与next的效果相同。

2、唯一的区别是next方法传输的参数回到正常值。throw方法传输的参数是错误的对象。

并且throw将该迭代器状态设置为迭代结束。

实例

function* generatorFunc () {
    console.log('function start...')
    let res = yield 1
    console.log('logger - 1', res)
    res = yield 2
    console.log('logger - 2', res)
    res = yield 3
    console.log('logger - 3', res)
    return 'function end...'
}
 
const generator = generatorFunc()
generator.next() // 执行到 yield 1 语句停止
/**
* print: 'function start...'
* returns: { value: 1, done: false }
*/
// 若传递一个错误对象
generator.next(new Error('报错啦~')) // 执行到 yield 2 语句停止
/**
* print: 'logger - 1' [错误对象('报错啦~')]
* returns: { value: 2, done: false }
*/
generator.throw(new Error('报错啦~')) // 抛出错误,迭代结束
/**
* print: [错误对象('报错啦~')]
* returns: nothing...
*/
// 后续再调用 next() 返回 {value: undefined, done: true}

以上就是javascript中throw和next方法的比较,希望对大家有所帮助。更多Python学习指路:python基础教程

关注

关注公众号,随时随地在线学习

本教程部分素材来源于网络,版权问题联系站长!

底部广告图