Maison > interface Web > js tutoriel > Quel est l'ordre d'exécution de promise et setTimeout ? Explication détaillée de la séquence d'exécution de la fonction de promesse

Quel est l'ordre d'exécution de promise et setTimeout ? Explication détaillée de la séquence d'exécution de la fonction de promesse

云罗郡主
Libérer: 2018-11-21 15:52:14
avant
4909 Les gens l'ont consulté

Le contenu de cet article concerne l'ordre d'exécution de promise et setTimeout ? L'explication détaillée de la séquence d'exécution de la fonction de promesse a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. J'espère qu'elle vous sera utile.

Une fois dans une question d'entretien, j'ai posé des questions sur l'ordre d'exécution de promise et setTimeout. J'étais un peu confus à l'époque, et l'ordre d'exécution était encore un peu faux, je vais l'enregistrer ici.

1. Sortie

setTimeout(function() {
console.log(111)
}, 0);
setTimeout(function() {
console.log(333)
}, 1000);
new Promise(function(resolve){
console.log(444);
resolve();
console.log(555);
})。then(function(){
console.log(666);
});
console.log(777);
async function test1() {
console.log("test1");
await test2();
console.log("test1 last");
}
async function test2() {
console.log("test2");
}
test1();
Copier après la connexion

Résultats de sortie

Quel est lordre dexécution de promise et setTimeout ? Explication détaillée de la séquence dexécution de la fonction de promesse

2. , puis s'exécute de manière asynchrone selon une méthode d'interrogation d'événements. La promesse d'implémentation asynchrone dans le code

est maintenant. alors() et .

dans catch() et le code de synchronisation dans la fonction dans la promesse

Le code ci-dessus exécute d'abord le code de synchronisation dans la promesse, puis exécute le code de synchronisation dans le script lui-même

async Que la méthode soit synchrone ou asynchrone, vous pouvez utiliser le mot-clé async pour l'identifier

Parce que l'identification asynchrone montre seulement qu'au sein de la méthode, le mot-clé wait peut être utilisé pour en faire une méthode asynchrone .De plus, la méthode asynchrone est clairement divisée.Ce n'est que lorsque le mot-clé wait est utilisé qu'il s'agit d'une opération asynchrone, et les autres sont des opérations synchrones

Identique à la fonction Generator, la fonction async renvoie un objet Promise, et vous pouvez utiliser then La méthode ajoute une fonction de rappel

Lorsque la fonction est exécutée, une fois qu'elle rencontre wait, elle reviendra d'abord, attendra que l'opération asynchrone déclenchée soit terminée, puis exécutera les instructions suivantes dans le corps de la fonction

Après l'objet Promise de la commande wait, le résultat en cours d'exécution peut être rejeté, il est donc préférable de mettre la commande wait dans le bloc de code try...catch

Autres

3. 🎜>

J'ai également trouvé des informations sur Internet et fait référence à cet article. Pour du contenu, veuillez vous référer à l'article

setImmediate(function(){
console.log(1);
},0);
setTimeout(function(){
console.log(2);
},0);
new Promise(function(resolve){
console.log(3);
resolve();
console.log(4);
})。then(function(){
console.log(5);
});
console.log(6);
process.nextTick(function(){
console.log(7);
});
console.log(8);
Copier après la connexion
Résultats de sortie : 3 4 6 8 7 5 2 1

macro-tâche : script (code global), setTimeout, setInterval, setImmediate, I/O, rendu UI.

micro-tâche : process.nextTick, Promise (native), Object.observe, MutationObserver

Première étape. Le code global du script est exécuté et le processus d'exécution est

Créer une macro-tâche setImmediate

Créer une macro-tâche setTimeout
Créer une micro-tâche Promise.then callback et exécuter le script console.log ( 3) ; solve(); console.log(4); À ce stade, 3 et 4 sont affichés. Bien que la résolution soit appelée et exécutée, le code global n'a pas été exécuté et ne peut pas entrer dans le processus Promise.then.
console.log (6) Sortie 6
process.nextTick Créer une micro-tâche
console.log (8) Sortie 8

Après le premier processus, 3 4 6 a été généré 8

La deuxième étape. Parce que les autres micro-tâches ont une priorité plus élevée que les macro-tâches.

À l'heure actuelle, il y a deux tâches dans la micro-tâche selon le processus prioritaire. nextTick est supérieur à Promise, donc 7 est sorti en premier, puis 5 est sorti.

Le Troisième étape, la liste des tâches des micro-tâches a été Une fois l'exécution terminée, descendez et exécutez la macro-tâche Puisque setTimeout a une priorité plus élevée que setIImmediate, 2 est sorti en premier, puis 1 est sorti.

Priorité : promise.Trick()>promise callback>setTimeout>setImmediate

Ce qui précède est quel est l'ordre d'exécution de promise et setTimeout ? Une introduction complète à l'explication détaillée de la séquence d'exécution de la fonction de promesse. Si vous souhaitez en savoir plus sur le

Tutoriel JavaScript, veuillez faire attention au site Web PHP chinois.



Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:segmentfault.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal