🎶 Sym - 一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)平台

📕 思源笔记 - 一款桌面端笔记应用,支持 Windows、Mac 和 Linux

🎸 Solo - B3log 分布式社区的博客端节点,欢迎加入下一代社区网络

♏ Vditor - 一款浏览器端的 Markdown 编辑器

`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 秒


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

9 评论
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 工作😄

bdFK3000 • 2019-01-31
回复 删除

Async/Await + try catch