亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

Inhaltsverzeichnis
Verwenden Sie das Babel -Plugin, um nicht mehrver?nderte Daten für JavaScript
Analyse
konvertieren
erzeugen
Heim Web-Frontend js-Tutorial Verstehen Sie ASTS, indem Sie Ihr eigenes Babel -Plugin erstellen

Verstehen Sie ASTS, indem Sie Ihr eigenes Babel -Plugin erstellen

Feb 18, 2025 am 09:24 AM

Verwenden Sie das Babel -Plugin, um nicht mehrver?nderte Daten für JavaScript

zu fügen zu fügen

In diesem Artikel wird erl?utert, wie ein Babel -Plugin geschrieben wird, um javaScript standardm??ig unver?nderliche Daten hinzuzufügen. Der Artikel erl?utert das Konzept des abstrakten Syntaxbaums (AST) und seine Rolle im Babel-Plug-In in der Tiefe und zeigt, wie man eine M?glichkeit erstellt, normale Objekte und Array-Literale in anhaltende Datenstrukturen in der Mori-Bibliothek durch schrittweise Beispiele für Schrittcode.

Kernpunkte:

  • Das Babel -Plugin konvertiert JavaScript -Code, indem ein abstrakter Syntaxbaum (AST) betrieben wird, mit dem Entwickler JavaScript -Funktionen wie unver?nderliche Datenstrukturen hinzufügen k?nnen.
  • AST ist für das Verst?ndnis der Struktur und der Syntaxdarstellung des Codes von wesentlicher Bedeutung, was für Aufgaben wie Codekonvertierung und Codestil -überprüfung unerl?sslich ist.
  • Erstellen eines Babel -Plugins beinhaltet das Parsen des Codes in ein AST, durchqueren und m?glicherweise das ?ndern dieses AST und das Generieren des ge?nderten Codes zum Standard -JavaScript -Format.
  • Verwenden von Online -Tools wie AST Explorer k?nnen Entwickler AST visualisieren und damit Babel -Plugins entwickeln und debuggen.
  • Dieses Tutorial zeigt die praktischen Schritte zum Erstellen eines Babel -Plugins, von der Einrichtung einer Entwicklungsumgebung bis hin zum Schreiben einer spezifischen Transformationslogik für die Handhabung von Arrays, Objekten und Zuordnungen in JavaScript.

Sprachübersicht:

Unser Ziel ist es, ein Plugin zu entwerfen, mit dem wir regul?re Objekt- und Array -Literale verwenden k?nnen, die mithilfe der Mori -Bibliothek in anhaltende Datenstrukturen konvertiert werden.

Wir m?chten so Code schreiben:

var foo = { a: 1 };
var baz = foo.a = 2;
foo.a === 1;
baz.a === 2;

und konvertieren Sie es in den folgenden Code:

var foo = mori.hashMap('a', 1);
var baz = mori.assoc(foo, 'a', 2);
mori.get(foo, 'a') === 1;
mori.get(baz, 'a') === 2;

Beginnen wir mit Moriscript !

Babel -übersicht:

Wenn wir uns mit Babel befassen, werden wir drei wichtige Tools finden, die den gr??ten Teil des Prozesses abwickeln.

Understanding ASTs by Building Your Own Babel Plugin

Analyse

babylon ist ein Parser, der wei?, wie JavaScript-Code-Zeichenfolgen in computerfreundliche Darstellungen umwandeln, die als abstrakte Syntaxb?ume (ASTS) bezeichnet werden.

konvertieren

Mit dem

babel-traverse -Modul k?nnen Sie AST erforschen, analysieren und m?glicherweise ?ndern.

erzeugen

Schlie?lich wird das

-Modul verwendet, um den konvertierten AST in den regul?ren Code zurückzuwandeln. babel-generator

Was ist AST?

Bevor Sie dieses Tutorial fortsetzen, ist es wichtig, den Zweck von AST zu verstehen. Lassen Sie uns in das ausgraben, was sie sind und warum wir sie brauchen.

JavaScript -Programme bestehen normalerweise aus einer Reihe von Charakteren, die jeweils mit einer gewissen visuellen Bedeutung für unser menschliches Gehirn sind. Dies funktioniert sehr gut für uns, da wir übereinstimmende Zeichen (

, [], {}), Zeichenpaare ((), '') und eingestuft werden k?nnen, um unser Programm einfacher zu erkl?ren. ""

Dies hilft jedoch nicht viel für den Computer. Für sie ist jeder Charakter nur ein numerischer Wert im Speicher und sie k?nnen diese Zeichen nicht verwenden, um erweiterte Fragen wie "Wie viele Variablen gibt es in dieser Erkl?rung?" Stattdessen müssen wir Kompromisse eingehen und einen Weg finden, unseren Code in etwas umzuwandeln, das wir programmieren k?nnen, und Computer k?nnen verstehen. Siehe den folgenden Code:

Wenn wir AST für dieses Programm generieren, erhalten wir eine Struktur, wie unten gezeigt:

var foo = { a: 1 };
var baz = foo.a = 2;
foo.a === 1;
baz.a === 2;

Alle ASTs beginnen mit dem Programmknoten an der Wurzel des Baumes, der alle Top-Ebenen im Programm enth?lt. In diesem Fall haben wir nur zwei:

Understanding ASTs by Building Your Own Babel Plugin

Eine Variableerklaration mit einem Variableklarator, der die Kennung "A" dem numerischen "3" zuweist.

Eine ExpressionStatement, die wiederum aus einer Binaryexpression besteht, wird als Kennung "A", als Operator "und ein weiterer numerischer" 5 "beschrieben.
  1. Obwohl sie aus einfachen Bausteinen bestehen, bedeutet die Gr??e von ASTS, dass sie oft sehr komplex sind, insbesondere für nicht triviale Programme. Anstatt zu versuchen, AST selbst herauszufinden, k?nnen wir Atexplorer.net verwenden, mit dem wir JavaScript links eingeben und dann eine explorierbare AST -Darstellung auf der rechten Seite ausgeben k?nnen. Im weiteren Verlauf werden wir dieses Tool speziell verwenden, um den Code zu verstehen und zu experimentieren.
Um mit Babel übereinzustimmen, w?hlen Sie "babylon6" als Parser.

Beim Schreiben von Babel -Plugin ist es unsere Aufgabe, das AST zu erhalten und dann einige Knoten einfügen/mov/ersetzen/l?schen, um ein neues AST zu erstellen, mit dem der Code generiert werden kann.

Einstellungen:

Vor dem Start stellen Sie sicher, dass Node und NPM installiert sind. Erstellen Sie dann einen Ordner für das Projekt, erstellen Sie eine Datei und installieren Sie die folgenden Entwicklungsabh?ngigkeiten.

Wir erstellen dann eine Datei für unser Plugin und exportieren eine Standardfunktion darin. package.json

var foo = mori.hashMap('a', 1);
var baz = mori.assoc(foo, 'a', 2);
mori.get(foo, 'a') === 1;
mori.get(baz, 'a') === 2;
Diese Funktion enth?lt die Schnittstelle des Besuchermodus, und wir werden sp?ter dorthin zurückkehren.

Schlie?lich werden wir einen L?ufer erstellen, um unser Plugin w?hrend der Zeit zu testen.
var a = 3;
a + 5

Wir k?nnen dieses Skript mit dem Namen der Moriscript -Beispieldatei aufrufen, um zu überprüfen, ob es das erwartete JavaScript generiert. Zum Beispiel

.

mkdir moriscript && cd moriscript
npm init -y
npm install --save-dev babel-core

(Folgendes führt weiter und natürlicher

Das obige ist der detaillierte Inhalt vonVerstehen Sie ASTS, indem Sie Ihr eigenes Babel -Plugin erstellen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erkl?rung dieser Website
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

Hei?e KI -Werkzeuge

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

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.

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem v?llig kostenlosen KI-Gesichtstausch-Tool aus!

Hei?e Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Hei?e Themen

PHP-Tutorial
1488
72
Wie stelle ich eine HTTP -Anforderung in node.js? Wie stelle ich eine HTTP -Anforderung in node.js? Jul 13, 2025 am 02:18 AM

Es gibt drei g?ngige M?glichkeiten, HTTP-Anforderungen in Node.js zu initiieren: Verwenden Sie integrierte Module, Axios und Knotenfetch. 1. Verwenden Sie das integrierte HTTP/HTTPS-Modul ohne Abh?ngigkeiten, das für grundlegende Szenarien geeignet ist, jedoch eine manuelle Verarbeitung von Datengen?hten und Fehlerüberwachung erfordert, z. 2.Axios ist eine auf Versprechen basierende Bibliothek von Drittanbietern. Es verfügt über eine kurze Syntax und leistungsstarke Funktionen, unterstützt Async/Auseait, automatische JSON -Konvertierung, Interceptor usw. Es wird empfohlen, asynchrone Anforderungsvorg?nge zu vereinfachen. 3.Node-Fetch bietet einen Stil ?hnlich dem Browser-Abruf, basierend auf Versprechen und einfacher Syntax

JavaScript -Datentypen: Primitive VS -Referenz JavaScript -Datentypen: Primitive VS -Referenz Jul 13, 2025 am 02:43 AM

JavaScript -Datentypen sind in primitive Typen und Referenztypen unterteilt. Zu den primitiven Typen geh?ren String, Anzahl, Boolesche, Null, undefiniertes und Symbol. Die Werte sind unver?nderlich und Kopien werden bei der Zuweisung von Werten kopiert, sodass sie sich nicht gegenseitig beeinflussen. Referenztypen wie Objekte, Arrays und Funktionen speichern Speicheradressen, und Variablen, die auf dasselbe Objekt zeigen, wirkt sich gegenseitig aus. Typeof und Instanz k?nnen verwendet werden, um die Typen zu bestimmen, aber auf die historischen Probleme der TypeOfnull zu achten. Das Verst?ndnis dieser beiden Arten von Unterschieden kann dazu beitragen, einen stabileren und zuverl?ssigeren Code zu schreiben.

JavaScript Time Object, jemand erstellt eine EACTEXE, schnellere Website auf Google Chrome usw. JavaScript Time Object, jemand erstellt eine EACTEXE, schnellere Website auf Google Chrome usw. Jul 08, 2025 pm 02:27 PM

Hallo, JavaScript -Entwickler! Willkommen in den JavaScript -Nachrichten dieser Woche! Diese Woche konzentrieren wir uns auf: Oracas Markenstreit mit Deno, neue JavaScript -Zeitobjekte werden von Browsern, Google Chrome -Updates und einigen leistungsstarken Entwickler -Tools unterstützt. Fangen wir an! Der Markenstreit von Oracle mit dem Versuch von Deno Oracle, ein "JavaScript" -Marke zu registrieren, hat Kontroversen verursacht. Ryan Dahl, der Sch?pfer von Node.js und Deno, hat eine Petition zur Absage der Marke eingereicht, und er glaubt, dass JavaScript ein offener Standard ist und nicht von Oracle verwendet werden sollte

Was ist die Cache -API und wie wird sie bei Dienstangestellten verwendet? Was ist die Cache -API und wie wird sie bei Dienstangestellten verwendet? Jul 08, 2025 am 02:43 AM

Cacheapi ist ein Tool, das der Browser zur Cache -Netzwerkanfragen bereitstellt, das h?ufig in Verbindung mit dem Servicearbeiter verwendet wird, um die Leistung der Website und die Offline -Erfahrung zu verbessern. 1. Es erm?glicht Entwicklern, Ressourcen wie Skripte, Stilbl?tter, Bilder usw. Zu speichern; 2. Es kann die Cache -Antworten entsprechend den Anfragen übereinstimmen. 3. Es unterstützt das L?schen bestimmter Caches oder das L?schen des gesamten Cache. 4.. Es kann Cache -Priorit?ts- oder Netzwerkpriorit?tsstrategien durch Servicearbeiter implementieren, die sich auf Fetch -Ereignisse anh?ren. 5. Es wird h?ufig für die Offline -Unterstützung verwendet, die wiederholte Zugriffsgeschwindigkeit, die Vorspannungs -Schlüsselressourcen und den Inhalt des Hintergrundaktualisierungss beschleunigen. 6. Wenn Sie es verwenden, müssen Sie auf die Cache -Versionskontrolle, Speicherbeschr?nkungen und den Unterschied zum HTTP -Caching -Mechanismus achten.

Handlingversprechen: Verkettung, Fehlerbehandlung und Versprechenkombinatoren in JavaScript Handlingversprechen: Verkettung, Fehlerbehandlung und Versprechenkombinatoren in JavaScript Jul 08, 2025 am 02:40 AM

Versprechen ist der Kernmechanismus für den Umgang mit asynchronen Operationen in JavaScript. Das Verst?ndnis von Kettenanrufen, Fehlerbehebung und Kombination ist der Schlüssel zum Beherrschen ihrer Anwendungen. 1. Der Kettenaufruf gibt ein neues Versprechen durch .then () zurück, um asynchrone Prozessverkampferung zu realisieren. Jeder. Dann () erh?lt das vorherige Ergebnis und kann einen Wert oder ein Versprechen zurückgeben; 2. Die Fehlerbehandlung sollte .Catch () verwenden, um Ausnahmen zu fangen, um stille Ausf?lle zu vermeiden, und den Standardwert im Fang zurückgeben, um den Prozess fortzusetzen. 3. Combinatoren wie Promise.All () (erfolgreich erfolgreich erfolgreich nach allen Erfolg), Versprechen.Race () (Die erste Fertigstellung wird zurückgegeben) und Versprechen.Allsettled () (Warten auf alle Fertigstellungen)

Nutzung von Array.Prototyp -Methoden zur Datenmanipulation in JavaScript Nutzung von Array.Prototyp -Methoden zur Datenmanipulation in JavaScript Jul 06, 2025 am 02:36 AM

JavaScript-Array-integrierte Methoden wie .Map (), .filter () und .Reduce () k?nnen die Datenverarbeitung vereinfachen. 1) .Map () wird verwendet, um Elemente eins in eins um Neuarrays zu konvertieren; 2) .Filter () wird verwendet, um Elemente durch Bedingung zu filtern; 3) .Reduce () wird verwendet, um Daten als einzelner Wert zu aggregieren; Missbrauch sollte bei der Verwendung vermieden werden, was zu Nebenwirkungen oder Leistungsproblemen führt.

JS Roundup: Ein tiefes Eintauchen in die JavaScript -Ereignisschleife JS Roundup: Ein tiefes Eintauchen in die JavaScript -Ereignisschleife Jul 08, 2025 am 02:24 AM

Die Ereignisschleife von JavaScript verwaltet asynchrone Vorg?nge, indem sie Call -Stapel, Webapis und Task -Warteschlangen koordinieren. 1. Der Anrufstack führt synchronen Code aus, und wenn er auf asynchrone Aufgaben begegnet, wird er zur Verarbeitung an Webapi übergeben. 2. Nachdem das Webapi die Aufgabe im Hintergrund abgeschlossen hat, wird der Rückruf in die entsprechende Warteschlange (Makroaufgabe oder Micro -Aufgabe) eingebaut. 3. Die Ereignisschleife prüft, ob der Anrufstapel leer ist. Wenn es leer ist, wird der Rückruf aus der Warteschlange herausgenommen und zur Ausführung in den Anrufstapel geschoben. V. 5. Das Verst?ndnis der Ereignisschleife hilft zu vermeiden, den Haupt -Thread zu blockieren und die Codeausführungsreihenfolge zu optimieren.

Ereignis verstehen und in JavaScript DOM -Ereignissen sprudeln und erfassen Ereignis verstehen und in JavaScript DOM -Ereignissen sprudeln und erfassen Jul 08, 2025 am 02:36 AM

Ereignisblasen verbreiten sich vom Zielelement nach au?en zum Vorfahrknoten aus, w?hrend Ereignisfassungen sich von der ?u?eren Schicht nach innen zum Zielelement ausbreiten. 1. Ereignisblasen: Nach dem Klicken auf das untergeordnete Element l?st das Ereignis den H?rer des übergeordneten Elements nach oben aus. Nach dem Klicken auf die Schaltfl?che gibt es beispielsweise zuerst die untergeordnete und dann entzündete Eltern aus. 2. Ereigniserfassung: Stellen Sie den dritten Parameter auf True ein, so dass der H?rer in der Erfassungsstufe ausgeführt wird, z. B. das Ausl?sen des Capture -Listeners des übergeordneten Elements, bevor Sie auf die Schaltfl?che klicken. 3. Praktische Verwendungszwecke umfassen ein einheitliches Management von Ereignissen für Kinderelemente, Vorverarbeitung und Leistungsoptimierung von Abfangen. V.

See all articles