Heim > Web-Frontend > js-Tutorial > Wie können Sie Fehler in asynchronen Rückrufen behandeln, die nicht im Rahmen eines Versprechens liegen?

Wie können Sie Fehler in asynchronen Rückrufen behandeln, die nicht im Rahmen eines Versprechens liegen?

Mary-Kate Olsen
Freigeben: 2024-10-26 10:06:02
Original
936 Leute haben es durchsucht

How Can You Handle Errors in Asynchronous Callbacks That Are Not Within a Promise's Scope?

Asynchrone Fehlerbehandlung mit Promise Chaining

Bei der Arbeit mit asynchronem Code ist es wichtig zu überlegen, wie Fehler effektiv behandelt werden können. Nicht abgefangene Ausnahmen können Ihre Anwendung zum Absturz bringen, daher ist es wichtig, eine Strategie zu haben.

Im beschriebenen Szenario wird ein Promise mit einem setTimeout erstellt, das einen Fehler auslöst. Der Catch-Handler von Bluebird Promise fängt diesen Fehler nicht ab, da er innerhalb eines asynchronen Rückrufs auftritt.

Ausnahmebehandlung innerhalb von Promises

Promises können jedoch Ausnahmen abfangen, die darin ausgelöst werden eigene Callback-Funktionen. Um diese Art von Fehler zu behandeln, können Sie:

<code class="javascript">function getPromise() {
  return new Promise(function(done, reject) {
    setTimeout(done, 500);
  }).then(function() {
    console.log("hihihihi");
    throw new Error("Oh no!");
  });
}</code>
Nach dem Login kopieren

Hier wird der Fehler innerhalb des then-Rückrufs ausgelöst, was sicherstellt, dass er vom Catch-Handler des Promise abgefangen wird.

Vorbehalte bei asynchronen Rückrufen

Es ist wichtig, sich daran zu erinnern, dass Versprechen keine Ausnahmen von asynchronen Rückrufen abfangen, die nicht in ihrem eigenen Zuständigkeitsbereich liegen. Um diese Art von Fehlern zu behandeln, sollten Sie Folgendes in Betracht ziehen:

  1. Verwendung von Promise.delay: Promise.delay umschließt einen asynchronen Rückruf, um ein Promise zurückzugeben. Alle innerhalb des Rückrufs ausgelösten Fehler werden vom Versprechen abgefangen.
  2. Das umgebende Versprechen ablehnen: Lehnen Sie nach Möglichkeit das Versprechen ab, das den asynchronen Rückruf umgibt, anstatt eine Ausnahme auszulösen.

Beispiel für die Handhabung von nicht autorisierten asynchronen Rückrufen

Um einen nicht autorisierten asynchronen Rückruf in Node.js oder im Browser zu verarbeiten, können Sie den folgenden Ansatz verwenden:

<code class="javascript">function getPromise() {
  return new Promise(function(done, reject) {
    setTimeout(function() {
      try {
        // Your rogue async callback here
        console.log("hihihihi");
      } catch (e) {
        reject(e);
      }
    }, 500);
  });
}</code>
Nach dem Login kopieren

Durch die manuelle Behandlung aller Ausnahmen innerhalb des Rückrufs stellt dieser Ansatz sicher, dass Ihre Anwendung nicht zum Absturz kommt.

Das obige ist der detaillierte Inhalt vonWie können Sie Fehler in asynchronen Rückrufen behandeln, die nicht im Rahmen eines Versprechens liegen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage