Promise Constructor
Promise constructor
The Promise constructor:
- is %Promise%.
- is the initial value of the "Promise" property of the global object.
- creates and initializes a new Promise when called as a constructor.
- is not intended to be called as a function and will throw an exception when called in that manner.
- may be used as the value in an extends clause of a class definition. Subclass constructors that intend to inherit the specified Promise behaviour must include a super call to the Promise constructor to create and initialize the subclass instance with the internal state necessary to support the Promise and Promise.prototype built-in methods.
Promise
This function performs the following steps when called:
- If NewTarget is undefined, throw a TypeError exception.
- If IsCallable(executor) is false, throw a TypeError exception.
- Let promise be ? OrdinaryCreateFromConstructor(NewTarget, "%Promise.prototype%", « [[PromiseState]], [[PromiseResult]], [[PromiseFulfillReactions]], [[PromiseRejectReactions]], [[PromiseIsHandled]] »).
- Set promise.[[PromiseState]] to PENDING.
- Set promise.[[PromiseFulfillReactions]] to a new empty List.
- Set promise.[[PromiseRejectReactions]] to a new empty List.
- Set promise.[[PromiseIsHandled]] to false.
- Let resolvingFunctions be CreateResolvingFunctions(promise).
- Let completion be Completion(Call(executor, undefined, « resolvingFunctions.[[Resolve]], resolvingFunctions.[[Reject]] »)).
- If completion is an abrupt completion, then a. Perform ? Call(resolvingFunctions.[[Reject]], undefined, « completion.[[Value]] »).
- Return promise.
Note
Note 1:
The executor argument must be a function object. It is called for initiating and reporting completion of
the possibly deferred action represented by this Promise. The executor is called with two arguments:
resolve and reject. These are functions that may be used by the executor function to report eventual
completion or failure of the deferred computation. Returning from the executor function does not mean
that the deferred action has been completed but only that the request to eventually perform the deferred
action has been accepted.
Note
Note 2:
The resolve function that is passed to an executor function accepts a single argument. The executor code may
eventually call the resolve function to indicate that it wishes to resolve the associated Promise. The argument
passed to the resolve function represents the eventual value of the deferred action and can be either the actual
fulfillment value or another promise which will provide the value if it is fulfilled.
Note
Note 3:
The reject function that is passed to an executor function accepts a single argument. The executor code may
eventually call the reject function to indicate that the associated Promise is rejected and will never be
fulfilled. The argument passed to the reject function is used as the rejection value of the promise.
Typically it will be an Error object.
Note
Note 4:
The resolve and reject functions passed to an executor function by the Promise constructor have the capability
to actually resolve and reject the associated promise. Subclasses may have different constructor behaviour that
passes in customized values for resolve and reject.