Tiefgehende Kenntnisse von JavaScriptPromise.all()
Promise.all()
ist eine leistungsstarke Methode in JavaScript zur gleichzeitigen Verarbeitung mehrerer asynchroner Vorgänge. Es empfängt ein iterierbares Objekt (normalerweise ein Array), das mehrere Versprechen enthält, und gibt ein einzelnes Versprechen zurück. Dieses einzelne Versprechen wird nur dann aufgelöst, wenn alle eingegebenen Versprechen erfolgreich gelöst werden. Wenn ein Versprechen abgelehnt wird, wird das einzelne Versprechen sofort abgelehnt. In diesem Leitfaden werden die Funktionalität, Syntax, das Verhalten und praktische Beispiele von Promise.all()
erläutert.
Promise.all()
ist einfach:
<code class="language-javascript">Promise.all(iterable);</code>
Diese Methode gibt ein Promise mit dem folgenden Verhalten zurück:
Promise.all()
ein Array von Ergebnissen in derselben Reihenfolge wie die Eingabe-Promises zurück. Promise.all()
wird es sofort abgelehnt und der Ablehnungsgrund des Versprechens wird zurückgegeben. In diesem Beispiel erstellen wir drei Versprechen, die nach unterschiedlichen Zeitüberschreitungen aufgelöst werden:
<code class="language-javascript">const promise1 = new Promise((resolve) => setTimeout(() => resolve('One'), 1000)); const promise2 = new Promise((resolve) => setTimeout(() => resolve('Two'), 2000)); const promise3 = new Promise((resolve) => setTimeout(() => resolve('Three'), 3000)); Promise.all([promise1, promise2, promise3]) .then(values => console.log(values)) // 输出: ['One', 'Two', 'Three'] .catch(error => console.error(error));</code>
Hier wartet Promise.all()
auf die Auflösung aller drei Promises und protokolliert dann ihre Ergebnisse als Array in der Konsole.
Sie können auch gelöste Werte und Versprechen mischen:
<code class="language-javascript">const p1 = Promise.resolve(42); const p2 = Promise.resolve('Hello'); const p3 = new Promise((resolve) => setTimeout(() => resolve('World'), 1000)); Promise.all([p1, p2, p3]) .then(values => console.log(values)) // 输出: [42, 'Hello', 'World'] .catch(error => console.error(error));</code>
In diesem Fall werden p1 und p2 sofort aufgelöst, während p3 nach einer Sekunde aufgelöst wird.
Wenn eines der Versprechen abgelehnt wird, Promise.all()
wird es sofort abgelehnt:
<code class="language-javascript">const p1 = Promise.resolve(42); const p2 = Promise.reject(new Error('Failed!')); const p3 = new Promise((resolve) => setTimeout(() => resolve('This will not run'), 1000)); Promise.all([p1, p2, p3]) .then(values => console.log(values)) .catch(error => console.error(error.message)); // 输出: 'Failed!'</code>
Da p2 abgelehnt wird, schlägt der gesamte Vorgang fehl und es wird eine Fehlermeldung protokolliert.
Anwendungsszenarien vonPromise.all()
Promise.all()
ist ein wesentliches Tool zum Verwalten mehrerer asynchroner Vorgänge in JavaScript. Es vereinfacht den Code, indem es Entwicklern ermöglicht, auf die Auflösung mehrerer Promises zu warten, bevor sie mit anderer Logik fortfahren. Es ist jedoch von entscheidender Bedeutung, mit Fehlern richtig umzugehen, da der Fehler eines einzelnen Versprechens dazu führt, dass der gesamte Vorgang fehlschlägt. Wenn Sie wissen, wie Sie Promise.all()
effektiv nutzen, können Sie saubereren und effizienteren asynchronen Code schreiben.
Referenzen: [1] https://www.php.cn/link/ebd58b8a3f1d72f4206201da62fb1204 [2] https://www.php.cn/link/9181a74736d3b86345dadbc90e29390e [3] https://www.php.cn/link/2a3e953a5e3d81e67945bce5519f84c8 [4] https://www.php.cn/link/4c0303ffb193bd5e66078909a15268aa [5] https://www.php.cn/link/9c25dc28b94e5226f1983330dc421cec [6] https://www.php.cn/link/b2f1384b8feb04d2de9a85124dc64613 [7] https://www.php.cn/link/f1e1fd9e97f59379ed79bdf258d55042 [8] https://www.php.cn/link/9a5859b8f76280c97c0c185a19d17014 [9] https://www.php.cn/link/d3f010d6bc392b904f63ce5792891b71 [10] https://www.php.cn/link/4d419d5b4274ea8faaf4f37410b97bd6
Das obige ist der detaillierte Inhalt vonPromise.all(). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!