"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Comment gérer les rappels asynchrones à l’aide d’Await ?

Comment gérer les rappels asynchrones à l’aide d’Await ?

Publié le 2024-11-11
Parcourir:948

How to Handle Asynchronous Callbacks Using Await?

Gestion des rappels asynchrones avec Await

Dans certains scénarios, lors de l'utilisation de rappels tels que :

test() {
  api.on( 'someEvent', function( response ) {
    return response;
  });
}

vous devrez peut-être intégrer l'asynchronicité. Pour rendre cette fonction asynchrone et utiliser wait, vous devez d'abord vous assurer que la fonction de rappel (someEvent) renvoie une promesse. En effet, les fonctions asynchrones s'appuient sur des promesses pour effectuer des opérations asynchrones.

Une version révisée de api.on() :

function apiOn(event) {
  return new Promise(resolve => {
    api.on(event, response => resolve(response));
  });
}

En utilisant cette fonction mise à jour, vous pouvez désormais modifier test() pour en faire une fonction asynchrone :

async function test() {
  return await apiOn( 'someEvent' );
}

Cependant, les fonctions asynchrones renvoient également des promesses, donc la valeur réelle du résultat de test() est une promesse qui peut être résolue dans une autre fonction asynchrone :

async function whatever() {
  // snip
  const response = await test();
  // use response here
  // snip
}
Dernier tutoriel Plus>

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