美文网首页前端开发
Promise、Generator、Async三者的区别

Promise、Generator、Async三者的区别

作者: SailingBytes | 来源:发表于2019-04-23 18:01 被阅读125次

    Promise有三种状态:pending(进行中)、resolved(成功)、rejected(失败)

    Promise对象的缺点:

    1、无法取消Promise,一旦新建它就会立即执行,无法中途取消。

    2、如果不设置回调函数,Promise内部抛出的错误,不会反应到外部。

    3、当处于Pending状态时,无法得知目前进展到哪一个阶段(刚刚开始还是即将完成)。

    4、Promise 真正执行回调的时候,定义 Promise 那部分实际上已经走完了,所以 Promise 的报错堆栈上下文不太友好。

    Generator 是ES6引入的新语法,Generator是一个可以暂停和继续执行的函数。

    简单的用法,可以当做一个Iterator来用,进行一些遍历操作。复杂一些的用法,他可以在内部保存一些状态,成为一个状态机。

    Generator 基本语法包含两部分:函数名前要加一个星号;函数内部用 yield 关键字返回值。

    yield表达式本身没有返回值,或者说总是返回undefined。

    next方法可以带一个参数,该参数就会被当作上一个yield表达式的返回值。

    function * foo(x) {

        var y = 2 * (yield (x + 1));

        var z = yield (y / 3);

        return (x + y + z);

    }

    var b = foo(5); 

    b.next() // { value:6, done:false }

    b.next(12) // { value:8, done:false } 

    b.next(13) // { value:42, done:true }

    Async 是 Generator 的一个语法糖。

    async 对应的是 * 。

    await 对应的是 yield 。

    async/await 自动进行了 Generator 的流程控制。

    async function fetchUser() {

      const user = await ajax()

      console.log(user)

    }

    相关文章

      网友评论

        本文标题:Promise、Generator、Async三者的区别

        本文链接:https://www.haomeiwen.com/subject/carbgqtx.html