Heim >Web-Frontend >js-Tutorial >Warum verursacht die Verwendung von „setTimeout' in einer Promise-Kette einen JSON-Parsing-Fehler?
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!