ES6 Promise对象

2018-04-29  本文已影响0人  o0ther

在了解Promise对象之前,我们有必要先来了解一下什么是回调。其实大家对于回调应该都不陌生。将函数作为参数,当主函数运行时,我们需要在合适的时候调用作为参数函数,但是又不影响函数的运行,这时候就用到了回调。举个例子

function func1(func2,a){
        if(a > 0){
                func2();
        }
        console.log("我是主函数");
}
function func2() {
        setTimeout("console.log('我是回调函数')",1000);
}
func1(func2,10);
//我是主函数
//我是回调函数

Promise对象

当我们的回掉函数很简单时,我们能很容易的分辨出结构,但是当回调函数很复杂时,根据业务需求可能会有很多层,这是就变得难以辨别,所以为了解决这一问题,Promise对象出现了。Promise 是异步编程的一种解决方案,比传统的解决方案——回调函数和事件——更合理和更强大。它由社区最早提出和实现,ES6 将其写进了语言标准,统一了用法,原生提供了Promise对象。

Promise对象的用法

var p = new Promise(function(resolve, reject) {
  // ... some code

  if (/* success */){
    resolve(value);
  } else {
    reject(error);
  }
});

注意:promise实例生成后会立即执行

Promise实例生成以后,可以用then方法分别指定resolved状态和rejected状态的回调函数。

p.then(function(value) {
  // success
}, function(error) {
  // failure
});

注:rejected状态函数可以省略

上一篇下一篇

猜你喜欢

热点阅读