Constructeur Promise()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
Le constructeur Promise()
est principalement utilisé afin d'envelopper des fonctions qui ne prennent pas en charge les promesses.
Exemple interactif
Syntaxe
new Promise(executeur);
Paramètres
executeur
-
Une fonction à exécuter par le constructeur lors de la construction du nouvel objet
Promise
.executeur
contient du code spécifique qui relie le résultat d'une opération à une promesse. C'est le programme qui doit fournir ce code. Sa signature doit être :jsfunction(fonctionResolution, fonctionRejet){ // généralement une opération asynchrone }
fonctionResolution
etfonctionRejet
sont également des fonctions, qu'on peut nommer librement. Ces deux fonctions prennent un seul paramètre, qui peut être de n'importe quel type.jsfonctionResolution(valeur) // appelée lors de la résolution fonctionRejet(raison) // appelée lors du rejet
Le paramètre
valeur
defonctionResolution
peut être une autre promesse, auquel cas la promesse est insérée dynamiquement dans la chaîne de promesses.Quant à
executeur
, il est important de comprendre :- Que la valeur de retour de
executeur
est ignorée. - Que si une erreur est déclenchée pendant l'exécution de
executeur
, la promesse est rejetée.
Ainsi, voici le mécanisme par lequel
executeur
produit un effet :- Au moment où le constructeur génère le nouvel objet
Promise
, il génère également une paire de fonctions correspondantesfonctionResolution
etfonctionRejet
qui sont « reliées » à l'objetPromise
. - Le code contenu dans
executeur
peut réaliser une opération et refléter le résultat de l'opération (si la valeur n'est pas un autre objetPromise
) en object) comme étant « résolue » ou « rejetée » en appelant respectivementfonctionResolution
oufonctionRejet
. - Autrement dit, le code contenu dans
executeur
communique par l'effet de bord fourni avecfonctionResolution
oufonctionRejet
. De cette façon, la promesse devient « résolue » ou « rejetée ».
Pour résumer, voici les étapes généralement suivies :
- L'opération portée par
executeur
est asynchrone et fournit une fonction de rappel (callback). - La fonction de rappel est définie au sein du code de
executeur
. - La fonction de rappel se termine en invoquant
fonctionResolution
. - L'invocation de
fonctionResolution
se fait avec un paramètrevaleur
. valeur
est passée en retour à l'objetPromise
.- L'objet
Promise
appelle, de façon asynchrone, toute fonction passée via.then(gestionSucces)
. - La valeur reçue par
.then(gestionSucces)
est passée comme paramètre d'entrée àgestionSucces
qui est appelée (voir l'enchaînement des promesses).
- Que la valeur de retour de
Valeur de retour
Lorsqu'il est appelé avec l'opérateur new
, le constructeur Promise()
renvoie un objet Promise
. Cette promesse sera résolue lorsque l'une des fonctions fonctionResolution
ou fonctionRejet
sera appelée. Si on passe une promesse comme argument à fonctionResolution
ou fonctionRejet
, on pourra dire que la promesse courante est résolue, mais pas que la chaîne de promesses est terminée.
Exemples
Créer une nouvelle promesse
On crée un objet Promise
en utilisant le constructeur avec l'opérateur new
. Ce constructeur prend une fonction en argument, et cette fonction prend à son tour deux fonctions en paramètres. La première de ces deux fonctions est appelée lorsque la tâche asynchrone se termine correctement, c'est alors le résultat de l'opération qui est passé comme paramètre. La seconde fonction est appelée lorsque la tâche échoue et c'est alors la raison de l'échec (généralement un objet d'erreur) qui est passée en argument.
const maPremierePromesse = new Promise((resolution, rejet) => {
// réaliser une opération asynchrone qui appellera :
//
// resolution(uneValeur) // réussite
// ou
// rejet("raison d'échec") // échec
});
Renvoyer une promesse depuis une fonction
Pour qu'une fonction ait les fonctionnalités d'une promesse, on lui fera renvoyer une promesse :
function maFonctionAsync(url) {
return new Promise((resolution, rejet) => {
const xhr = new XMLHttpRequest();
xhr.open("GET", url);
xhr.onload = () => resolution(xhr.responseText);
xhr.onerror = () => rejet(xhr.statusText);
xhr.send();
});
}
Spécifications
Specification |
---|
ECMAScript Language Specification # sec-promise-constructor |
Compatibilité des navigateurs
BCD tables only load in the browser