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!