Ja. Promise ist ein neuer Referenztyp in ECMAScript 6, der den endgültigen Abschluss oder Misserfolg einer asynchronen Operation darstellt. Promise löst das Problem des übermäßig komplexen Schreibens von Logik beim Aufrufen von Code für die asynchrone Programmierung. Wenn die Netzwerkanforderung sehr komplex ist, wird es zu einer Rückrufhölle kommen. Wenn diese Codes zusammen geschrieben werden, sehen sie sehr kompliziert aus und sind nicht lesbar. Wenn Sie Promises verwenden, sieht der Code schöner und eleganter aus.
Die Betriebsumgebung dieses Tutorials: Windows 7-System, ECMAScript Version 6, Dell G3-Computer.
ECMAScript 6 bietet vollständige Unterstützung für die Promises/A+-Spezifikation, nämlich den Promise-Typ. Nach seiner Einführung erfreute sich Promise großer Beliebtheit und wurde zum dominierenden asynchronen Programmiermechanismus. Alle modernen Browser unterstützen die ES6-Erwartungen und viele andere Browser-APIs basieren auf den Erwartungen.
Promise ist ein neuer Referenztyp in ECMAScript 6, der den endgültigen Abschluss oder Misserfolg einer asynchronen Operation darstellt.
1. Was ist die Promise-Funktion? Die Promise-Funktion soll das Problem des übermäßig komplexen Schreibens der Aufrufcodelogik im Netzwerk lösen, wenn diese Codes also zusammen geschrieben werden Es sieht sehr kompliziert aus und ist nicht lesbar. Wenn Sie Promise verwenden, sieht der Code schöner und eleganter aus. 2. Drei Zustände von Promise. Erstens, wenn wir asynchrone Vorgänge in unserer Entwicklung haben kann ein Versprechen für die asynchrone Operation einpacken Nach der asynchronen Operation gibt es drei Zustände
1, dann und fangen
1. Funktionen im ausstehenden Zustand sind synchron und werden es auch sein Sofort ausgeführt
2. Then und Catch sind asynchron. Auch wenn im Promise-Objekt keine asynchrone Operation vorhanden ist und die Then-Methode oder Catch sofort ausgeführt wird, können die beiden Methoden hier zur Ereigniswarteschlange hinzugefügt werden, um auf die Ausführung zu warten pending:等待状态,比如正在进行网络请求,或者定时器没有到时间。
fulfill:满足状态,当我们主动回调了resolve时,就处于该状态,并且会回调.then()
reject:拒绝状态,当我们主动回调了reject时,就处于该状态,并且会回调.catch()
2. Bestimmen Sie den Status1. Wenn in der Funktion zur Verarbeitung des ausstehenden Status ein nicht erfasster Fehler auftritt, wird der Status ausstehend und wird direkt zum abgelehnten Status und kann von catach
3 erfasst werden und warten
1. Verwenden Sie Promise:
//参数 函数(resolve,reject) new Promise((resolve, reject) => { setTimeout(() => { //请求成功的时候调用resolve resolve('22222') //请求失败的时候调用reject reject('error message') }, 1000) }).then((data) => { //请求成功处理函数 console.log(data) }).catch((err) => { //请求失败处理函数 console.log(err) })
2. Verwenden Sie Async:
async und waiting werden von ES7 vorgeschlagenDie Rolle von async:Vereinfachen Sie die Erstellung von Promise-Objekten in Funktionsrückgabewerten
Im Allgemeinen wird async am Ende der Funktion geschrieben. Zuvor muss der Rückgabewert der geänderten Funktion ein Versprechensobjekt sein. Nur in einigen Sonderfällen wird ein Promise-Objekt manuell zurückgegeben.
Funktion: Lösen Sie asynchrone Probleme wie Promise, aber der Vorteil besteht darin, dass asynchroner Code mit synchronem Code identisch ist!!Hinweis: Bei synchronen Methoden erhalten wir die Ergebnisse über Rückgabewerte und bei asynchronen Methoden erhalten wir die Ergebnisse durch Rückruffunktion.
Diegrundlegende Syntax, die von Async und Wait verwendet wird:
besteht darin, vor der normalen Funktion ein Async hinzuzufügen. Der Aufruf ist derselbe wie bei der normalen Funktion.
Async wird im Allgemeinen in Verbindung mit Wait verwendet Auf
await folgt ein Promise-Objekt-Await, das in einer asynchronen Funktion verwendet werden muss.
var pro = new Promise((resolve, reject) => { throw new Error("123"); // try{ // throw new Error("123"); // } catch(e) {} resolve(12); reject(34); }) // pro.then(data => { // console.log(data); // }, err => { // console.log(err); // }) console.log(pro); pro.then(data => { console.log(data); }) pro.catch(data => { console.log(data); })
- 3. Unterschied: 1. Vor der Funktion steht ein zusätzliches aync-Schlüsselwort. Das Schlüsselwort „await“ kann nur innerhalb von aync definierter Funktionen verwendet werden. Die asynchrone Funktion gibt implizit ein Versprechen zurück, und der Auflösungswert des Versprechens ist der Wert der Funktionsrückgabe. (Der reosolve-Wert im Beispiel ist die Zeichenfolge „done“)
2. Wir können „await“ nicht im äußersten Code verwenden, da es nicht innerhalb der asynchronen Funktion liegt.
- 4.promise-Methode
const makeRequest = () => getJSON().then(data => { console.log(data) return "done" }) makeRequest()
1.all-Methode -
Manchmal müssen wir warten, bis zwei oder mehr Anfragen erfolgreich zurückgegeben werden, bevor wir mit dem nächsten Schritt fortfahren. Die All-Methode von Promise besteht darin, auf alle asynchronen Anfragen zu warten abgeschlossen sein. Im nächsten Schritt des Rückrufs werden gleichzeitig Anfragen gesendet. Wer zuerst zurückkommt, verwendet dessen Daten.
const makeRequest = async () => { // await getJSON()表示console.log会等到getJSON的promise成功reosolve之后再执行。 console.log(await getJSON) return "done" } makeRequest()
var r1 = new Promise((resolve,reject) => {
setTimeout(function(){
resolve("我是第一个请求");
},1000)
})
var r2 = new Promise((resolve,reject) => {
setTimeout(function(){
resolve("我是第二个请求");
},3000)
})
var r3 = new Promise((resolve,reject) => {
setTimeout(function(){
resolve("我是第三个请求");
},4000)
})
var r4 = new Promise((resolve,reject) => {
setTimeout(function(){
resolve("我是第四个请求");
},500)
})
[Verwandte Empfehlungen:
,
Web-Frontend
Das obige ist der detaillierte Inhalt vonBasiert das Versprechen auf es6?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Die Beziehung zwischen HTML und React ist der Kern der Front-End-Entwicklung und erstellt gemeinsam die Benutzeroberfläche moderner Webanwendungen. 1) HTML definiert die Inhaltsstruktur und die Semantik und erstellt eine dynamische Schnittstelle durch Komponenten. 2) React -Komponenten verwenden die JSX -Syntax, um HTML einzubetten, um intelligentes Rendering zu erreichen. 3) Komponentenlebenszyklus verwaltet HTML -Rendering und aktualisiert dynamisch nach Zustand und Attributen. 4) Verwenden Sie Komponenten, um die HTML -Struktur zu optimieren und die Wartbarkeit zu verbessern. 5) Die Leistungsoptimierung umfasst die Vermeidung unnötiger Rendering, die Verwendung von Schlüsselattributen und die Einhaltung der einzigen Verantwortung der Komponente.

React ist das bevorzugte Werkzeug zum Aufbau interaktiver Front-End-Erlebnisse. 1) React vereinfacht die UI -Entwicklung durch Komponentierungen und virtuelles DOM. 2) Komponenten werden in Funktionskomponenten und Klassenkomponenten unterteilt. Funktionskomponenten sind einfacher und Klassenkomponenten bieten mehr Lebenszyklusmethoden. 3) Das Arbeitsprinzip von React beruht auf virtuellen DOM- und Versöhnungsalgorithmus, um die Leistung zu verbessern. 4) State Management verwendet Usestate oder diese. 5) Die grundlegende Verwendung umfasst das Erstellen von Komponenten und das Verwalten von Status, und die erweiterte Verwendung umfasst benutzerdefinierte Haken und Leistungsoptimierung. 6) Zu den häufigen Fehlern gehören unsachgemäße Statusaktualisierungen und Leistungsprobleme, Debugging -Fähigkeiten umfassen die Verwendung von ReactDevtools und exzellent

React ist eine JavaScript -Bibliothek zum Erstellen von Benutzeroberflächen mit ihren Kernkomponenten und staatlichen Verwaltung. 1) Vereinfachen Sie die UI -Entwicklung durch Komponentierungen und Staatsmanagement. 2) Das Arbeitsprinzip umfasst Versöhnung und Rendering, und die Optimierung kann durch React.Memo und Usememo implementiert werden. 3) Die grundlegende Verwendung besteht darin, Komponenten zu erstellen und zu rendern, und die erweiterte Verwendung umfasst die Verwendung von Hooks und ContextAPI. 4) Häufige Fehler wie eine unsachgemäße Status -Update können Sie ReactDevtools zum Debuggen verwenden. 5) Die Leistungsoptimierung umfasst die Verwendung von React.

React kombiniert JSX und HTML, um die Benutzererfahrung zu verbessern. 1) JSX bettet HTML ein, um die Entwicklung intuitiver zu gestalten. 2) Der virtuelle DOM -Mechanismus optimiert die Leistung und reduziert den DOM -Betrieb. 3) Komponentenbasierte Verwaltungs-Benutzeroberfläche zur Verbesserung der Wartbarkeit. 4) Staatsmanagement und Ereignisverarbeitung verbessern die Interaktivität.

React -Komponenten können durch Funktionen oder Klassen definiert werden, wobei die UI -Logik eingefasst und Eingabedaten durch Props akzeptiert werden. 1) Komponenten definieren: Verwenden Sie Funktionen oder Klassen, um Reaktierungselemente zurückzugeben. 2) Rendering -Komponente: React -Aufrufe rendern Methode oder führt die Funktionskomponente aus. 3) Multiplexing -Komponenten: Daten durch Requisiten übergeben, um eine komplexe Benutzeroberfläche zu erstellen. Mit dem Lebenszyklusansatz von Komponenten kann die Logik in verschiedenen Phasen ausgeführt werden, wodurch die Entwicklungseffizienz und die Wartbarkeit des Codes verbessert werden.

React Strict Mode ist ein Entwicklungstool, das potenzielle Probleme in React -Anwendungen hervorhebt, indem zusätzliche Überprüfungen und Warnungen aktiviert werden. Es hilft, den Legacy -Code, unsichere Lebenszyklen und Nebenwirkungen zu identifizieren und moderne Reaktionspraktiken zu fördern.

React -Fragmente ermöglichen es, Kinder ohne zusätzliche Dom -Knoten zu gruppieren und Struktur, Leistung und Zugänglichkeit zu verbessern. Sie unterstützen Schlüssel für die effiziente Listenrendern.

In dem Artikel wird der Versöhnungsprozess von React erläutert und beschreibt, wie er das DOM effizient aktualisiert. Zu den wichtigsten Schritten gehören das Auslösen der Versöhnung, das Erstellen eines virtuellen DOM, die Verwendung eines differenzierenden Algorithmus und die Anwendung minimaler DOM -Updates. Es deckt auch Perfo ab


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

mPDF
mPDF ist eine PHP-Bibliothek, die PDF-Dateien aus UTF-8-codiertem HTML generieren kann. Der ursprüngliche Autor, Ian Back, hat mPDF geschrieben, um PDF-Dateien „on the fly“ von seiner Website auszugeben und verschiedene Sprachen zu verarbeiten. Es ist langsamer und erzeugt bei der Verwendung von Unicode-Schriftarten größere Dateien als Originalskripte wie HTML2FPDF, unterstützt aber CSS-Stile usw. und verfügt über viele Verbesserungen. Unterstützt fast alle Sprachen, einschließlich RTL (Arabisch und Hebräisch) und CJK (Chinesisch, Japanisch und Koreanisch). Unterstützt verschachtelte Elemente auf Blockebene (wie P, DIV),

DVWA
Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

SecLists
SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.