Sym - 一个用 Java 实现的现代化社区平台 • 源码注册

Pipe - 小而美的开源博客平台 • 体验皮肤
Solo - 一个用 Java 实现的博客系统,为你或你的团队创建个博客吧! • 源码下载
Wide - 一个基于 Web 的 Go 语言 IDE • 教程试用

`Promise` 有哪些状态?

2019-01-06

回答

Promise 对象用于表示一个异步操作的最终状态(完成或失败)及其返回值。他有以下几种状态:

  • pending:初始状态,完成或失败状态的前一个状态
  • fulfilled:操作成功完成
  • rejected:操作失败

pending 状态的 Promise 对象会触发 fulfilled/rejected 状态,在其状态处理方法中可以传入参数 / 失败信息。当操作成功完成时,Promise 对象的 then 方法就会被调用;否则就会触发 catch。如:

const myFirstPromise = new Promise((resolve, reject) => {
    setTimeout(function(){
        resolve("成功!"); 
    }, 250);
});

myFirstPromise.then((data) => {
    console.log("Yay!" + data);
}).catch((e) => {...});

加分回答

异步编程还包含了以下几种

  • 回调函数,如:
    $('body).click(() => {  
     alert(`clicked on body`);  
    });
  • generator,如:
    function * gen (x) {
      const y = yield x + 2;
    }
    const g = gen(1);
    console.log('first', g.next());  // {value: 3, done: false}
    console.log('second', g.next()); // {value: undefined, done: true}
  • Async/Await
    async function readJsonFile() {
      try {
          const file = await readFile('../generator/config.json');
          console.log(file.toString());
      } catch (e) {
          console.log('出错啦');
      }
    }

返回总目录

每天 30 秒


欢迎注册黑客派社区,开启你的博客之旅。让学习和分享成为一种习惯!

8 评论
XPPA • 2019-01-07
回复 删除

前端也开始用 Promise 了么😳

telami • 2019-01-07
回复 删除

ES6、ES7 早就用了

Vanessa • 2019-01-07
回复 删除

嗯, annotations 都开始用了

alshin • 2019-01-07
回复 删除

Async/Await 其实我还是觉得不是很方便,因为总是要配套起来用,写多了就繁琐了,应该加一个顶级的 root async, 这样会方便很多。

Vanessa • 2019-01-07
回复 删除

不知道这样考虑是不是性能问题?

alshin • 2019-01-07
回复 删除

不清楚呢,网上有很多争论。

Vanessa • 2019-01-07
回复 删除

有次不知道咋漏写 await 了,然后调试半天。。。被自己蠢哭了

alshin • 2019-01-08
回复 删除

这怪 D 没做好 Review 工作😄