Maison interface Web js tutoriel Comment quitter les fonctions de rappel dans Async / AWAIT Élégamment?

Comment quitter les fonctions de rappel dans Async / AWAIT Élégamment?

Apr 04, 2025 pm 05:03 PM
typescript 浏览器 ai 点击事件

Comment quitter les fonctions de rappel dans Async / AWAIT Élégamment?

Terminer gracieusement la fonction de rappel dans Async / Await

Comment sortir en toute sécurité d'une fonction de rappel avec un temps d'exécution incertain est un défi commun lors de l'utilisation de l'async / attendre des opérations asynchrones. Cet article fournira un scénario pour démontrer comment contrôler efficacement la sortie de la fonction de rappel dans l'environnement asynchrone / attendre.

Problème: Le code utilise MutationObserver pour écouter les modifications des propriétés des boutones. Lorsque les propriétés changent, vous devez quitter la fonction asynchrone. L'écriture traditionnelle de la promesse est facile à mettre en œuvre, mais lorsque le code est complexe, la promesse imbriquée réduira la lisibilité et la maintenabilité. L'objectif est de réécrire le code au style async / attendre tout en résolvant le problème de la façon de quitter la fonction asynchrone dans la fonction de rappel.

Exemple de code:

 // utilise la méthode d'écriture traditionnelle de promesse consta = (): promesse<void> => {
  retourner la nouvelle promesse ((résolution) => {
    const Callback = (mutations: mutationRecord []) => {
      // Écoutez les modifications de l'attribut du bouton, quittez la fonction résolve () ici;
    };
    const Observer = new MutationObserver (rappel);
    Observe.Observe (BUTUTEL, {Attributs: true});

    // Appelez la fonction de promesse, déclenchez l'événement de clic du bouton après le succès, puis écoutez les modifications de la propriété p (). Puis (() => {
      Buttonel.Click ();
    });
  });
};

// Utilisez Async / Await pour écrire const b = async (): promesse<void> => {
  const Callback = (mutations: mutationRecord []) => {
    // Écoutez les modifications des attributs de bouton, comment quitter la fonction ici?
  };
  const Observer = new MutationObserver (rappel);
  Observe.Observe (BUTUTEL, {Attributs: true});

  // Appelez la fonction de promesse, déclenchez l'événement de clic du bouton après le succès, puis écoutez les modifications de la propriété Aide P ();
  Buttonel.Click ();
};</void></void>
Copier après la connexion

Solution:

Afin d'implémenter la même fonction que la fonction a dans Async / Await, vous pouvez utiliser Promise.withResolvers() . Cette méthode renvoie un objet contenant les fonctions de promesse et de résolution.

Code amélioré:

 const b = async (): promesse<void> => {
  const {promesse, résolve} = promest.withResolvers<void> ();

  const Callback = (mutations: mutationRecord []) => {
    résoudre(); // appelle résoudre () dans la fonction de rappel pour résoudre la promesse
  };
  const Observer = new MutationObserver (rappel);
  Observe.Observe (BUTUTEL, {Attributs: true});

  attendre p ();
  Buttonel.Click ();
  attendre la promesse; // attendez que la promesse résoudre};</void></void>
Copier après la connexion

Description de la compatibilité:

Promise.withResolvers() est actuellement au stade de la proposition et tous les navigateurs ne sont pas soutenus nativement. Pour garantir la compatibilité, des polyfills, tels que core-js , peuvent être nécessaires. De même, les utilisateurs de TypeScript doivent mettre à jour vers la version 5.4 ou plus et configurer lib pour inclure esnext dans tsconfig.json .

Avec Promise.withResolvers() , vous pouvez appeler resolve() dans la fonction de rappel pour résoudre la promesse, contrôlant ainsi efficacement le processus de sortie de la fonction asynchrone / attente, évitant la nidification complexe de promesses et améliorant la lisibilité et la maintenabilité du code.

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 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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Téléchargez le site officiel de l'application Oryi Exchange pour le téléphone mobile Apple Téléchargez le site officiel de l'application Oryi Exchange pour le téléphone mobile Apple Apr 28, 2025 pm 06:57 PM

L'application OUYI Exchange prend en charge le téléchargement des téléphones mobiles Apple, visitez le site officiel, cliquez sur l'option "Apple Mobile", obtenez-la et installez-la dans l'App Store, Inscrivez-vous ou connectez-vous pour effectuer le trading des crypto-monnaies.

Laquelle des dix principales plateformes de trading de devises au monde est la dernière version des dix principales plateformes de trading de devises Laquelle des dix principales plateformes de trading de devises au monde est la dernière version des dix principales plateformes de trading de devises Apr 28, 2025 pm 08:09 PM

Les dix principales plates-formes de trading de crypto-monnaie au monde comprennent Binance, Okx, Gate.io, Coinbase, Kraken, Huobi Global, BitFinex, Bittrex, Kucoin et Poloniex, qui fournissent toutes une variété de méthodes de trading et de puissantes mesures de sécurité.

Quelles sont les principales plateformes de trading de devises? Les 10 meilleurs échanges de devises virtuels virtuels Quelles sont les principales plateformes de trading de devises? Les 10 meilleurs échanges de devises virtuels virtuels Apr 28, 2025 pm 08:06 PM

Actuellement classé parmi les dix premiers échanges de devises virtuels: 1. Binance, 2. Okx, 3. Gate.io, 4. Coin Library, 5. Siren, 6. Huobi Global Station, 7. Bybit, 8. Kucoin, 9. Bitcoin, 10. Bit Stamp.

Comment utiliser la bibliothèque Chrono en C? Comment utiliser la bibliothèque Chrono en C? Apr 28, 2025 pm 10:18 PM

L'utilisation de la bibliothèque Chrono en C peut vous permettre de contrôler plus précisément les intervalles de temps et de temps. Explorons le charme de cette bibliothèque. La bibliothèque Chrono de C fait partie de la bibliothèque standard, qui fournit une façon moderne de gérer les intervalles de temps et de temps. Pour les programmeurs qui ont souffert de temps et ctime, Chrono est sans aucun doute une aubaine. Il améliore non seulement la lisibilité et la maintenabilité du code, mais offre également une précision et une flexibilité plus élevées. Commençons par les bases. La bibliothèque Chrono comprend principalement les composants clés suivants: std :: chrono :: system_clock: représente l'horloge système, utilisée pour obtenir l'heure actuelle. std :: chron

Combien vaut le bitcoin Combien vaut le bitcoin Apr 28, 2025 pm 07:42 PM

Le prix de Bitcoin varie de 20 000 $ à 30 000 $. 1. Le prix de Bitcoin a radicalement fluctué depuis 2009, atteignant près de 20 000 $ en 2017 et près de 60 000 $ en 2021. 2. Les prix sont affectés par des facteurs tels que la demande du marché, l'offre et l'environnement macroéconomique. 3. Obtenez des prix en temps réel via les échanges, les applications mobiles et les sites Web. 4. Le prix du bitcoin est très volatil, tiré par le sentiment du marché et les facteurs externes. 5. Il a une certaine relation avec les marchés financiers traditionnels et est affecté par les marchés boursiers mondiaux, la force du dollar américain, etc. 6. La tendance à long terme est optimiste, mais les risques doivent être évalués avec prudence.

Quelles sont les dix principales applications de trading de devises virtuelles? Le dernier classement de change de monnaie numérique Quelles sont les dix principales applications de trading de devises virtuelles? Le dernier classement de change de monnaie numérique Apr 28, 2025 pm 08:03 PM

Les dix premiers échanges de devises numériques tels que Binance, OKX, Gate.io ont amélioré leurs systèmes, des transactions diversifiées efficaces et des mesures de sécurité strictes.

Comment mesurer les performances du fil en C? Comment mesurer les performances du fil en C? Apr 28, 2025 pm 10:21 PM

La mesure des performances du thread en C peut utiliser les outils de synchronisation, les outils d'analyse des performances et les minuteries personnalisées dans la bibliothèque standard. 1. Utilisez la bibliothèque pour mesurer le temps d'exécution. 2. Utilisez le GPROF pour l'analyse des performances. Les étapes incluent l'ajout de l'option -pg pendant la compilation, l'exécution du programme pour générer un fichier gmon.out et la génération d'un rapport de performances. 3. Utilisez le module Callgrind de Valgrind pour effectuer une analyse plus détaillée. Les étapes incluent l'exécution du programme pour générer le fichier callgrind.out et la visualisation des résultats à l'aide de Kcachegrind. 4. Les minuteries personnalisées peuvent mesurer de manière flexible le temps d'exécution d'un segment de code spécifique. Ces méthodes aident à bien comprendre les performances du thread et à optimiser le code.

Binance Officielle Entrée Binance Binance Dernière entrée 2025 Binance Officielle Entrée Binance Binance Dernière entrée 2025 Apr 28, 2025 pm 07:54 PM

Visitez le site officiel de Binance et consultez les logos HTTPS et Green Lock pour éviter les sites Web de phishing, et les applications officielles sont également accessibles en toute sécurité.

See all articles