官术网_书友最值得收藏!

The states and return values of a promise

From Chapter 1, Promises.js, we are already aware that a promise is based on three states. Let's brush up our memory on these states, in accordance with promises paradigm.

Promise has three states:

  • Unfulfilled promise
  • Fulfilled promise
  • Failed promise

A promise exists within these three states.

The beginning of a promise is from an unfulfilled state. This is due to the fact that a promise is a proxy for an unknown value.

When the promise is filled with the value it's waiting for, it's in the fulfilled state. The promise will be labeled as failed if it returns an exception.

A promise may move from an unfulfilled to a fulfilled or failed state. Observers (or the objects/events waiting) are notified when the promise is either rejected or fulfilled. Once the promise is rejected or resolved, its output (value or state) cannot be modified.

The following code snippet will help you understand more easily than theory:

// Promise to be filled with future value
var futureValue = new Promise();

// .then() will return a new promise
var anotherFutureValue = futureValue.then();

// Promise state handlers (must be a function ).
// The returned value of the fulfilled / failed handler will be the value of the promise.
futureValue.then({

    // Called if/when the promise is fulfilled
    fulfilledHandler: function() {},

    // Called if/when the promise fails
    errorHandler: function() {},

    // Called for progress events (not all implementations of promises have this)
    progressHandler: function() {}
});
主站蜘蛛池模板: 孟州市| 灌云县| 兴仁县| 科技| 大同市| 若尔盖县| 兰溪市| 沾益县| 太湖县| 博湖县| 泗洪县| 敦煌市| 永定县| 游戏| 江安县| 兴和县| 陆河县| 无极县| 同江市| 惠东县| 宁陕县| 南投县| 德惠市| 临安市| 海林市| 舒城县| 上杭县| 昌乐县| 娄底市| 抚州市| 昆明市| 阿合奇县| 烟台市| 博野县| 天津市| 白玉县| 美姑县| 高淳县| 辽中县| 司法| 来宾市|