Comprendre l'ordre d'exécution dans les promesses JavaScript
Les promesses en JavaScript offrent un modèle de programmation asynchrone dans lequel le code est exécuté une fois un événement spécifique ou une promesse , est accompli. Cependant, lorsqu'il s'agit de plusieurs promesses, il est essentiel de comprendre l'ordre d'exécution pour éviter un comportement imprévisible.
Considérez l'extrait de code suivant :
Promise.resolve('A') .then(function(a){console.log(2, a); return 'B';}) .then(function(a){ Promise.resolve('C') .then(function(a){console.log(7, a);}) .then(function(a){console.log(8, a);}); console.log(3, a); return a;}) .then(function(a){ Promise.resolve('D') .then(function(a){console.log(9, a);}) .then(function(a){console.log(10, a);}); console.log(4, a);}) .then(function(a){ console.log(5, a);}); console.log(1); setTimeout(function(){console.log(6)},0);
Lors de l'exécution, vous pouvez observer l'ordre de sortie suivant :
1 2 "A" 3 "B" 7 "C" 4 "B" 8 undefined 9 "D" 5 undefined 10 undefined 6
Comprendre l'ordre d'exécution
Promise.resolve('A').then(function (a) { console.log(2, a); renvoyer 'B'; }).then(fonction (a) { var p = Promise.resolve('C').then(function (a) { console.log(7, a); }).then(fonction (a) { console.log(8, a); }); console.log(3, a); retourner p ; // Lier la promesse interne à la chaîne parent }).then(fonction (a) { var p = Promise.resolve('D').then(function (a) { console.log(9, a); }).then(fonction (a) { console.log(10, a); }); console.log(4, a); retourner p ; // Lier la promesse interne à la chaîne parent }).then(fonction (a) { console.log(5, a); }); console.log(1); setTimeout (fonction () { console.log(6) }, 0);
Avec cette approche, l'ordre d'exécution devient entièrement déterministe : 1, 2 "A", 3 "B", 7 "C", 8 non défini, 4 non défini, 9 "D", 10 non défini, 5 non défini et 6.Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.
Copyright© 2022 湘ICP备2022001581号-3