1 Was ist Webpack?
webpack ist ein statisches Modul-Bundler. Wenn Webpack eine Anwendung verarbeitet, erstellt es rekursiv ein Abhängigkeitsdiagramm, das jedes Modul enthält, das die Anwendung benötigt, und packt diese Module dann in ein oder mehrere Bundles.
Webpack ist wie eine Produktionslinie. Es muss eine Reihe von Verarbeitungsprozessen (Loadern) durchlaufen, bevor die Quelldateien in Ausgabeergebnisse umgewandelt werden können. Jeder Verarbeitungsprozess in dieser Produktionslinie hat eine einzige Verantwortung und es bestehen Abhängigkeiten zwischen mehreren Prozessen. Erst nachdem die aktuelle Verarbeitung abgeschlossen ist, kann sie zur Verarbeitung an den nächsten Prozess übergeben werden.
Ein Plug-In ist wie eine in die Produktionslinie eingefügte Funktion, die die Ressourcen auf der Produktionslinie zu einem bestimmten Zeitpunkt verarbeitet. Webpack sendet Ereignisse während des laufenden Prozesses. Das Plug-in muss nur die Ereignisse abhören, die es interessiert, und kann sich dieser Produktionslinie anschließen, um den Betrieb der Produktionslinie zu ändern.
2. Können Sie über den Verpackungsprozess/Bauprozess sprechen? 3. Können Sie über die Optimierung des Front-End-Betriebs sprechen? Webpacks Verpackungsprozess/Verpackungsprinzip/Bauprozess?
Die Befehlszeilenausführung des npx webpack
-Verpackungsbefehls beginnt 1.Kompilierungsparameter initialisieren
: Parameter aus Konfigurationsdateien und Shell-Befehlen lesen und zusammenführen
2.Kompilieren starten
: Initialisieren Sie das Compiler-Objekt gemäß den im vorherigen Schritt erhaltenen Parametern, laden Sie alle konfigurierten Plugins und führen Sie die Ausführungsmethode des Objekts aus, um die Kompilierung zu starten.
Eintrag ermitteln
: Alle Eintragsdateien entsprechend dem Eintrag in der Konfiguration finden 4. Modul kompilieren
: Aus der Eintragsdatei ausgelöst, alle konfigurierten Loader aufrufen, um das auszuführen Modul Übersetzen, ermitteln Sie dann die Module, von denen das Modul abhängt, und wiederholen Sie dann diesen Schritt, bis alle eintragsabhängigen Dateien übersetzt sind. npx webpack
打包命令开始
1.初始化编译参数
:从配置文件和shell命令中读取与合并参数
2.开始编译
:根据上一步得到的参数初始化Compiler对象,加载所有配置的Plugin,执行对象的 run 方法开始执行编译。
3.确定入口
:根据配置中的 entry 找出所有的入口文件
4.编译模块
:从入口文件触发,调用所有配置的Loader对模块进行翻译,再找出该模块依赖的模块,然后递归本步骤直到所有入口依赖的文件都进行翻译。
5.完成模块编译
:在经过第4步使用 Loader 翻译完所有模块后,得到了每个模块被翻译后的最终内容以及它们之间的依赖关系图。
6.输出资源
:根据依赖关系图,组装成一个个包含多个模块的Chunk,再把每个Chunk转化成一个单独的文件加入到输出列表,根据配置确定输出的路径和文件名,输出。
在以上过程中,Webpack
会在特定的时间点广播出特定的事件,插件在监听到感兴趣的事件后会执行特定的逻辑。
总结
Compiler编译对象掌控者webpack生命周期,不执行具体的任务,只是进行一些调度工作。比如执行模块创建、依赖收集、分块、打包等
6.
调用run之后,创建Compiltation实例,每次构建都会新创建一个Compiltation实例,包含了这次构建的基本信息Webpack
5.Modulkompilierung abschließen
: Nachdem in Schritt 4 Loader zum Übersetzen aller Module verwendet wurde, werden der endgültige übersetzte Inhalt jedes Moduls und das Abhängigkeitsdiagramm zwischen ihnen erhalten.Ausgaberessourcen
: Gemäß dem Abhängigkeitsdiagramm in Chunks mit mehreren Modulen zusammenstellen, dann jeden Chunk in eine separate Datei konvertieren und zur Ausgabeliste hinzufügen und die Ausgabe entsprechend der Konfiguration bestimmen Pfad und Dateiname, Ausgabe.
Webpack
bestimmte Ereignisse zu bestimmten Zeitpunkten, und das Plug-in führt eine bestimmte Logik aus, nachdem es die interessierenden Ereignisse abgehört hat. Initialisierung: Parameter aus der Konfigurationsdatei und dem Shell-Befehl lesen und zusammenführen, die Compiler-Instanz entsprechend den Parametern initialisieren, das Plugin laden (alle konfigurierten Plug-Ins registrieren), die Ausführungsmethode des Compilers aufrufen Instanz, um die Kompilierung zu starten.
Erstellen Sie nach dem Aufruf von run eine Kompilierungsinstanz. Jeder Build erstellt eine neue Kompilierungsinstanz, die die grundlegenden Informationen dieses Builds enthält
WebpackCode> sendet bestimmte Ereignisse zu bestimmten Zeitpunkten und das Plug-in führt eine bestimmte Logik aus, nachdem es die interessierenden Ereignisse abgehört hat.
Fügen Sie gemäß dem Abhängigkeitsdiagramm einen Chunk zusammen, der mehrere Module enthält, und konvertieren Sie jedes einzelne Chunk in Dateiausgabe.
Webpack bereitgestellter Mechanismus zur Verarbeitung mehrerer DateiformateDa Webpack nur JS und JSON kennt, entspricht Loader einem Übersetzer, der andere Arten von Ressourcen vorverarbeitet.
Wird zum Konvertieren des „Quellcodes“ des Moduls verwendet. 🎜 Der Loader unterstützt Kettenaufrufe und die Reihenfolge der Aufrufe ist von rechts nach links. **Jeder Loader in der Kette verarbeitet zuvor verarbeitete Ressourcen und wird schließlich zu JS-Code. 🎜 Durch die Vorverarbeitungsfunktionen des Loaders können Sie dem JavaScript-Ökosystem mehr Möglichkeiten bieten. 🎜🎜🎜🎜🎜Was sind die gängigen Lader? 🎜🎜🎜🎜less-Loader: Kompilieren Sie weniger Dateien in CSS-Dateien🎜🎜🎜🎜Während der Entwicklung verwenden wir häufig weniger Präprozessoren, um CSS-Stile zu schreiben und die Entwicklungseffizienz zu verbessern🎜
Plugin ist leistungsfähiger? Sein Hauptzweck besteht darin, Dinge zu lösen, die mit dem Loader nicht erreicht werden können, wie z. B. Verpackungsoptimierung und Codekomprimierung.
Nachdem das Plugin geladen wurde, werden die vom Plugin definierten Funktionen zu einem bestimmten Zeitpunkt während der Webpack-Erstellung ausgelöst, um Webpack dabei zu helfen, etwas zu tun. Implementieren Sie funktionale Erweiterungen für Webpack.
Ein Plug-In ist wie eine in die Produktionslinie eingefügte Funktion, die die Ressourcen auf der Produktionslinie zu einem bestimmten Zeitpunkt verarbeitet. Webpack sendet Ereignisse während des laufenden Prozesses. Das Plug-in muss nur die Ereignisse abhören, die es interessiert, und kann sich dieser Produktionslinie anschließen, um den Betrieb der Produktionslinie zu ändern.
Oder verwenden Sie die vorherige Zusammenfassung, um darüber zu sprechen, was Loader und Plugin jeweils sind Loader: 1. Herunterladen 2.
Plugin verwenden: 1. Herunterladen 2. Zitieren 3. Verwenden
Welche Optimierungsmethoden hat Webpack durchgeführt? Welche Optimierungsmethoden gibt es?
Wie verwende ich Webpack, um die Front-End-Leistung zu optimieren? Die Frage betrifft die Optimierung der Produktionsumgebung.
Wie kann die Build-Geschwindigkeit von Webpack verbessert werden? Die Frage betrifft die Optimierung der Build-Geschwindigkeit. Tree-Shaking löscht nicht verwendeten Code, um die Front-End-Leistung zu optimieren/Build-Geschwindigkeit zu erhöhen. Tree-Shaking ist eine Technologiepaketierung zur Eliminierung von totem Code, die auf der ES-Modulspezifikation basiert. Erkennen und markieren Sie während des Verpackungsprozesses die Module, auf die im Projekt nicht verwiesen wurde, löschen Sie die Module, auf die nicht verwiesen wurde, verbessern Sie die Build-Geschwindigkeit und verkürzen Sie die Programmlaufzeit.
Was ist beim Baumrütteln zu beachten?
1. Standardfunktion
.
mode = production
,生产环境默认开启tree-shaking
1. Sie können den Code in node__mudules separat in eine Chunk-Ausgabe packen (z. B. mit jqury? )
2. Es wird automatisch analysiert, ob öffentliche Dateien im Multi-Entry-Block vorhanden sind. Wenn vorhanden, wird dieser in einen separaten Block gepackt und nicht wiederholt gepackt -Packaging
Normalerweise wird node_module in eine Datei gepackt.
Verwenden Sie die DLL-Technologie, um Frameworks und Bibliotheken, die nicht häufig separat aktualisiert werden, zu verpacken und einen Block zu generieren.1. Konfigurieren Sie das Plug-in als Kompressor für die Komprimierung im Optimierungskonfigurationselement.
2. Verwenden Sie dieses Plug-in zur Komprimierung in PluginsKonsole löschen, Kommentare , Leerzeichen, Zeilenumbrüche, nicht verwendete CSS-Codes usw.css-Komprimierung: mit „optimize-css-assets-webpack-plugin“-Plugin
Idee 1: Reduzieren Sie die Dateien oder Codes, die erstellt werden müssen.
Normalerweise wird node_module in eine Datei gepackt
Mithilfe der DLL-Technologie können Frameworks und Bibliotheken, die nicht häufig aktualisiert werden, separat gepackt werden, um eine zu generieren chunk
Der Quellcode des Projekts muss ebenfalls aufgeteilt werden und kann auf der Route zum Teilen gepackter Dateien basieren –> Wie implementiert man das verzögerte Laden von Routen? Wie implementiert man das asynchrone Laden von Komponenten im Webpack? Idee 2: Mehr Konstruktion ausführen Daher sind mehrere Prozesse erforderlich. Verpackung
【Verwandte Empfehlungen:
Javascript-Video-TutorialDas obige ist der detaillierte Inhalt von[Zusammenstellung und Weitergabe] Einige Webpack-Interviewfragen (mit Antwortanalyse). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!