Teilen Sie diesen Artikel:

Blog
Aug 07, 20234 min read

Laravel Mix - ein einfacher und leistungsstarker Wrapper um Webpack

Stefani Tashkova

Junior-Entwickler

Laravel Mix - ein einfacher und leistungsstarker Wrapper um Webpack

Laravel-Mix

Wir werden über Laravel Mix sprechen. Um es besser zu verstehen, werden wir zunächst erklären, was Webpack ist.

Webpack ist ein unglaublich leistungsfähiger Modul-Bundler, der Ihr JavaScript und Ihre Assets für den Browser vorbereitet. Daher ist Mix eine dünne Schicht über Webpack, die dazu dient, Ihre Webpack-Konfiguration dynamisch zu erstellen. Obwohl Laravel Mix ursprünglich für Laravel-Projekte entwickelt wurde, kann es natürlich für jede Art von Anwendung verwendet werden.

Übersicht

Die neueste Version von Laravel Mix ist Version 6 und erfordert Abhängigkeiten, die mit Webpack 5 oder PostCSS 8 kompatibel sind. Es ist ein kostenloses Tool, das Ihre Assets automatisch optimiert und minimiert, wenn Sie sie mit dem Befehl npx mix --production für die Produktion erstellen, über den wir später sprechen werden.

Laravel Mix wird auch mit grundlegender Typescript- und View-Unterstützung ausgeliefert. Zur Unterstützung der langfristigen Zwischenspeicherung bietet Mix die Methode mix.version(). Bei aktivierter Versionierung wird jedes Mal, wenn Ihr Code kompiliert wird, eine eindeutige Query-String-ID an Ihre Assets angehängt, und nach der Kompilierung werden die gehashten Namen in der Datei mix-manifest.json angezeigt. Ein weiterer großer Vorteil der mix-API besteht darin, dass wir Herstellerbibliotheken isolieren oder in eigene Dateien extrahieren können, was natürlich zu einer deutlich kleineren app.js-Datei führt. Mit Hot Module Replacement können wir Module austauschen, hinzufügen oder entfernen, während eine Anwendung läuft, ohne sie komplett neu laden zu müssen. Alles, was wir tun müssen, ist, von der Kommandozeile aus npx mix watch --hot auszuführen, um einen Node-Server zu starten und unser Bundle auf Änderungen zu überwachen.

Mix bietet den Befehl mix.css() für die grundlegende CSS-Kompilierung und das iPostCSS-Plugin-Ökosystem als Teil unserer Kompilierung, und wir haben auch Optionen für die Kompilierung mit Sass und Less. Standardmäßig wird Mix alle unsere CSS durch das beliebte Autoprefixer PostCSS-Plugin leiten. Als solche sind wir frei, die neueste CSS 3-Syntax mit dem Verständnis, dass alle notwendigen Browser-Präfixe werden automatisch angewendet werden, zu verwenden. Ein wichtiges Konzept zu verstehen ist, dass Mix und Webpack wird alle URLs mit relativen Pfaden innerhalb unserer Stylesheets umschreiben, aber die absolute Pfade werden immer von URL Rewriting ausgeschlossen werden.

Installationsschritte

Hier sehen wir, wie man Laravel Mix installiert und einrichtet.

Zuerst sollten wir Mix entweder über npm oder yarn installieren.

npm install laravel-mix --save-dev

yarn add laravel-mix

Der zweite Schritt besteht darin, eine Mix-Konfigurationsdatei namens webpack.mix.js zu erstellen

webpack.mix.js berühren

Dann definieren wir dort unsere Kompilierung. In diesem Beispiel legen wir unseren öffentlichen Pfad fest und verwenden die mix sass-Kompilierung.

const mix = require('laravel-mix');
mix.setPublicPath(`dist`);
mix.sass('resources/scss/app.scss', `dist/css`);
mix.js('resources/js/app.js', 'dist/js')

Schließlich müssen wir nur noch einen npx mix-Befehl ausführen, um den entsprechenden Webpack-Build auszulösen.

Nützliche CLI-Befehle

  • Kompilieren in einer lokalen Umgebung

    npm-Mix
  • Assets auf Veränderungen überwachen

    npx mix uhr
  • Abfrage

    npx mix watch--watch-options-poll
  • Austausch des Heißmoduls

    npx mix watch --hot
  • Kompilieren für die Produktion

    npx mix --production
  • Anpassen des Mix-Konfigurationspfads

    npx mix --mix-config=build/webpack.mix.js -production

Nützliche Merkmale

  • Mix bietet einige andere nützliche Funktionen, zum Beispiel, wenn wir Anbieterbibliotheken haben, die von unserem Kern-Webpack-Bündel getrennt bleiben müssen, können wir mix.combine() verwenden, um mehrere Dateien in eine einzige Datei mit dem Namen merged.js zusammenzuführen oder zu verketten.
  • Eine weitere interessante Funktion ist browsersync, die unsere Dateien automatisch auf Änderungen überwacht und alle Änderungen in den Browser überträgt, ohne dass eine manuelle Aktualisierung erforderlich ist.
  • In bestimmten Fällen kann es sich als einfacher erweisen, eine Ebene tiefer zu gehen und die unterstrichene Webpack-Konfiguration direkt zu überschreiben, und mix bietet den mix.webpackConfig()-Befehl, um dies zu ermöglichen.
  • Schauen wir uns nun die Ereignis-Hooks an. In einigen Szenarien kann es notwendig sein, ein Stück Logik auszuführen, bevor die Kompilierung beginnt. Wenn wir zum Beispiel ein Verzeichnis kopieren oder eine Datei verschieben müssen, ermöglicht die mix.before() Funktion dies, und Mix beginnt erst mit der Kompilierung, wenn alle Hooks vollständig aufgelöst wurden. Auf der anderen Seite können wir ein Stück Logik ausführen, nachdem Webpack seine Kompilierung mit der mix.after() Methode abgeschlossen hat. Zum Beispiel, wenn man eine Liste aller kompilierten Assets protokollieren möchte.

Für weitere Informationen können Sie die offizielle Dokumentation von Laravel Mix besuchen.

ABONNIEREN SIE UNSEREN NEWSLETTER

Teilen Sie diesen Artikel:

ABONNIEREN SIE UNSEREN NEWSLETTER

Verwandte Blog-Artikel

    Warum Startups zögern, mit einer Agentur für maßgeschneiderte Softwareentwicklung zusammenzuarbeiten - und wie wir alle Bedenken ausräumen

    Blog

    Warum Startups zögern, mit einer Agentur für maßgeschneiderte Softwareentwicklung zusammenzuarbeiten - und wie wir alle Bedenken ausräumen

    <p>Start-ups zögern oft, mit Softwareagenturen zusammenzuarbeiten, weil sie Bedenken hinsichtlich Kosten, Kontrolle und Flexibilität haben. Entdecken Sie, wie die maßgeschneiderten Softwarelösungen von Bulcode jede Herausforderung meistern und für Wachstum und Flexibilität sorgen.</p>

    Geschrieben von Svetoslava Angelova
    Nov 05, 20246 min read
    Aufbau eines hochleistungsfähigen agilen Teams: Unser bewährter Ansatz

    Blog

    Aufbau eines hochleistungsfähigen agilen Teams: Unser bewährter Ansatz

    Erfahren Sie, wie wir leistungsstarke agile Teams aufbauen, indem wir klare Rollen definieren, die Zusammenarbeit fördern und flexible Tools einsetzen.

    Geschrieben von Svetoslava Angelova
    Aug 27, 20249 min read
    Drupal 11: Was ist zu erwarten? Umfassender Leitfaden zu neuen Funktionen und Erweiterungen

    Blog

    Drupal 11: Was ist zu erwarten? Umfassender Leitfaden zu neuen Funktionen und Erweiterungen

    Drupal 11 ist da! Entdecken Sie in diesem Artikel die spannenden Funktionen und Verbesserungen. Führen Sie jetzt ein Upgrade durch, um Ihre digitale Strategie mit dem Experten-Support von Bulcode neu zu definieren.

    Geschrieben von Svetoslava Angelova
    Aug 05, 20247 min read
    Einzelne Verzeichniskomponenten in Drupal core: Ein umfassender Überblick

    Blog

    Einzelne Verzeichniskomponenten in Drupal core: Ein umfassender Überblick

    Erfahren Sie, wie Single Directory Components (SDC) in Drupal Core den Entwicklungsprozess rationalisieren, indem komponentenbezogene Dateien in einem einzigen Verzeichnis gekapselt werden. Erfahren Sie mehr über die Vorteile von SDCs und folgen Sie einer Schritt-für-Schritt-Anleitung, um sie in Ihren Drupal-Projekten zu implementieren.

    Geschrieben von Nikolay Tsekov
    Aug 07, 20244 min read
    Drupal-Versionen verstehen und eine Migrationsstrategie planen

    Blog

    Drupal-Versionen verstehen und eine Migrationsstrategie planen

    Erkennen Sie die verschiedenen Drupal-Versionen und halten Sie Ihre Website auf dem neuesten Stand.

    Geschrieben von Svetoslava Angelova
    Aug 08, 20234 min read
    Drupal 9 Bild in WebP-Format konvertieren

    Blog

    Drupal 9 Bild in WebP-Format konvertieren

    WebP ist in der Lage, die Datenkomprimierung auf ein neues Niveau zu heben, da es einen Vorhersagemodus in den JPG-Prozess einfügt, der die Leistung seines JPG-Verwandten deutlich übertrifft. Und wir haben die Ergebnisse, um dies zu beweisen.

    Geschrieben von Vasil Boychev
    Aug 08, 20237 min read
    React im Überblick - Definition, SPA, Komponenten, Hooks

    Blog

    React im Überblick - Definition, SPA, Komponenten, Hooks

    React ist ein freies und quelloffenes JavaScript-Framework für die Erstellung von Benutzeroberflächen auf der Grundlage von UI-Komponenten. Es ist auch als React.js oder ReactJS bekannt.

    Geschrieben von Mihail Shahov
    Aug 07, 20236 min read
    Was ist Agile und warum verwenden wir es?

    Blog

    Was ist Agile und warum verwenden wir es?

    Agile ist eine zeitlich begrenzte, iterative Methode zur Softwarebereitstellung, die darauf abzielt, die Software schrittweise während des Projekts bereitzustellen und nicht alles auf einmal gegen Ende.

    Geschrieben von Svetoslava Angelova
    Aug 08, 20234 min read
    NVM vs NPM vs Yarn

    Blog

    NVM vs NPM vs Yarn

    Im Vergleich zu den drei Technologien unterscheidet sich der NVM von den beiden anderen. Der Node Version Manager (NVM) wird zur Verwaltung von Node.js-Versionen verwendet. NPM und Yarn sind Node.js-Paketmanager. Sie ermöglichen das Herunterladen, Installieren und Verwalten von Paketen bei der Entwicklung in JavaScript.

    Geschrieben von Ventsislav Venkov
    Aug 07, 20235 min read
    Welches Modell der IT-Verpflichtung passt am besten zu Ihnen?

    Blog

    Welches Modell der IT-Verpflichtung passt am besten zu Ihnen?

    Festpreis, Zeit und Material oder engagierte Teams? Wägen Sie sorgfältig alle Vor- und Nachteile des Auftragsmodells für Ihr Projekt ab.

    Geschrieben von Svetoslava Angelova
    Aug 07, 202310 min read
    Die Websites der Flughäfen Varna und Burgas verwenden React-Komponenten in Drupal

    Blog

    Die Websites der Flughäfen Varna und Burgas verwenden React-Komponenten in Drupal

    Drupal ist ein modulares System, dessen Funktionen an viele verschiedene Anforderungen angepasst werden können, was für Projekte der öffentlichen Verwaltung besonders wichtig ist.

    Geschrieben von Mihail Shahov
    Aug 08, 20234 min read
    Was ist Scrum?

    Blog

    Was ist Scrum?

    Scrum ist ein Teil der agilen Methodik. Es ist das beliebteste Framework für agile Entwicklung und ein einfaches Prozess-Framework.

    Geschrieben von Svetoslava Angelova
    Aug 08, 20234 min read

    KONTAKT AUFNEHMEN

    Sie haben ein Projekt, das Sie gerne starten würden?