Maison >interface Web >js tutoriel >Comment gérer les rappels asynchrones à l'aide d'Await ?

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

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-10-30 05:46:271044parcourir

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 pour 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 d'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() être 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
}

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!

Déclaration:
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