微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Generator 与 asnyc await

Generator 生成函数,返回一个迭代器对象,可以手动调用 next 方法来控制执行,throw 方法抛出错误return 方法来提前结束,也可以使用 for...of 自动遍历遍历。

function* gen() {
  yield 1;
  yield 2;
  yield 3;
}

let g = gen();
g.next(); // output: { value: 1, done: false }
g.next(); // output: { value: 2, done: false }
g.next(); // output: { value: 3, done: false }
g.next(); // output: { value: undefined, done: true }

for (const value of gen()) {
  console.log('value :>> ', value);
}
// output:
// value :>>  1
// value :>>  2
// value :>>  3

asnyc await 其实就是 Generator 的语法糖,只不过内置一个执行器,其返回值是一个 Promise 对象。

function* gen() {
  let a = yield Promise.resolve(1);
  let b = yield Promise.resolve(2);
  return 'end';
}

function run() {
  return new Promise((res, rej) => {
    try {
      const g = a();

      function next(data) {
        let n = g.next(data);
        if (n.done) return res(n.value);
        Promise.resolve(n.value).then(next, g.throw);
      }

      next();
    } catch (error) {
      rej(error);
    }
  });
}

run(gen);

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐