suchen
HeimWeb-FrontendFront-End-Fragen und AntwortenBasiert das Versprechen auf es6?

Basiert das Versprechen auf es6?

Nov 03, 2022 pm 07:20 PM
es6promise

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.

Basiert das Versprechen auf es6?

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 Status

1. 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 vorgeschlagen

Die 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.

Die

grundlegende 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()
Five.promise Encapsulation Ajax Case

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:

Javascript-Video-Tutorial

,
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!

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
HTML und React: Die Beziehung zwischen Markup und KomponentenHTML und React: Die Beziehung zwischen Markup und KomponentenApr 12, 2025 am 12:03 AM

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.

Reagieren und das Frontend: Bauen Sie interaktive Erlebnisse aufReagieren und das Frontend: Bauen Sie interaktive Erlebnisse aufApr 11, 2025 am 12:02 AM

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

Reagieren Sie und der Frontend Stack: die Werkzeuge und TechnologienReagieren Sie und der Frontend Stack: die Werkzeuge und TechnologienApr 10, 2025 am 09:34 AM

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.

Reacts Rolle bei HTML: Verbesserung der BenutzererfahrungReacts Rolle bei HTML: Verbesserung der BenutzererfahrungApr 09, 2025 am 12:11 AM

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.

Reagieren Sie Komponenten: Erstellen wiederverwendbarer Elemente in HTMLReagieren Sie Komponenten: Erstellen wiederverwendbarer Elemente in HTMLApr 08, 2025 pm 05:53 PM

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.

Reagieren Sie den strengen ModuszweckReagieren Sie den strengen ModuszweckApr 02, 2025 pm 05:51 PM

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.

Fragmente reagierenFragmente reagierenApr 02, 2025 pm 05:50 PM

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.

Reaktions VersöhnungsprozessReaktions VersöhnungsprozessApr 02, 2025 pm 05:49 PM

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

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

mPDF

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

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

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

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

MinGW – Minimalistisches GNU für Windows

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.