Heim  >  Artikel  >  Web-Frontend  >  Warum verursacht die Verwendung von „setTimeout' in einer Promise-Kette einen JSON-Parsing-Fehler?

Warum verursacht die Verwendung von „setTimeout' in einer Promise-Kette einen JSON-Parsing-Fehler?

Susan Sarandon
Susan SarandonOriginal
2024-10-30 05:49:28470Durchsuche

Why Does Using `setTimeout` in a Promise Chain Cause a JSON Parsing Error?

setTimeout in der Promise-Kette verwenden

Um Versprechen zu erkunden, haben Sie versucht, mithilfe einer ersten Anfrage eine Reihe von Links abzurufen und den Inhalt abzurufen Erster Link über eine Folgeanfrage. Um eine Verzögerung vor der Rückgabe des nächsten Promise-Objekts einzuführen, haben Sie setTimeout verwendet. Bei diesem Ansatz tritt jedoch ein JSON-Parsing-Fehler auf, der verschwindet, wenn setTimeout() eliminiert wird.

Um diesen Fehler zu erklären, ist es wichtig zu verstehen, dass Sie setTimeout() nicht verwenden können, um die Kontinuität der Versprechenskette aufrechtzuerhalten Das hast du getan. Der Grund dafür ist, dass Sie kein Versprechen vom .then()-Handler zurückgeben, sondern vom setTimeout()-Rückruf, was Ihre Bemühungen wirkungslos macht.

Erwägen Sie stattdessen die Implementierung einer einfachen Verzögerungsfunktion:

<code class="js">function delay(t, val) {
    return new Promise(resolve => setTimeout(resolve, t, val));
}</code>

Mit dieser Verzögerungsfunktion können Sie Ihren Code wie folgt ändern:

<code class="js">getLinks('links.txt').then(function(links){
    let all_links = (JSON.parse(links));
    globalObj=all_links;

    return getLinks(globalObj["one"]+".txt");

}).then(function(topic){
    writeToBody(topic);
    // return a promise here that will be chained to prior promise
    return delay(1000).then(function() {
        return getLinks(globalObj["two"]+".txt");
    });
});</code>

Diese Änderung stellt sicher, dass Sie ein Versprechen vom .then()-Handler zurückgeben. Dadurch wird es entsprechend verkettet.

Alternativ können Sie das Promise-Objekt mit einer Verzögerungsmethode erweitern, sodass Sie eine prägnantere Syntax verwenden können:

<code class="js">Promise.prototype.delay = function(t) {
    return this.then(function(val) {
        return delay(t, val);
    });
}

Promise.resolve("hello").delay(500).then(function(val) {
    console.log(val);
});</code>

Durch die Einbindung dieser Änderungen können Sie nahtlos Führen Sie Verzögerungen innerhalb Ihrer Versprechenskette ein und lindern Sie so den aufgetretenen JSON-Parsing-Fehler.

Das obige ist der detaillierte Inhalt vonWarum verursacht die Verwendung von „setTimeout' in einer Promise-Kette einen JSON-Parsing-Fehler?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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