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

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() {}
});
主站蜘蛛池模板: 琼海市| 科技| 中超| 苏尼特左旗| 监利县| 长海县| 建平县| 兴山县| 巴马| 辽阳县| 镇康县| 龙胜| 永城市| 安溪县| 舞阳县| 开原市| 广汉市| 乌兰浩特市| 长宁县| 扎鲁特旗| 闽侯县| 日照市| 舞阳县| 湖南省| 肥西县| 南城县| 江西省| 封丘县| 乐清市| 客服| 昌江| 霍林郭勒市| 兴和县| 咸阳市| 海盐县| 乐业县| 大姚县| 津市市| 秀山| 会东县| 思茅市|