Erstelltes Mikro-Frontend ( @org/angular-spa-frontend ), zusammen mit der URL ( http://localhost:4200/main.js ), in der sich das Mikro befindet Frontend wurde gehostet, muss in der Import-Map hinzugefügt werden.

Führen Sie dann den folgenden Befehl aus, um die App auszuführen.

npm run start

Vorausgesetzt, diese Schritte werden korrekt ausgeführt, sollten wir in der Ansicht das endgültige Einzel-Spa sehen können, ähnlich dem folgenden Bild.

\\\"Build

Schritt 2: Bereitstellung in der Produktion

Bei der Bereitstellung dieser Mikro-Frontends in der Produktion wird empfohlen, jede Mikro-Frontend-App als unabhängige, eigenständige App bereitzustellen. Die Root-Konfiguration wird vermutlich jede App dynamisch laden, abhängig von den App-Routen, die in der registerApplication festgelegt sind.

Schritt 3: Weitere Mikro-Frontends hinzufügen

Um weitere Mikro-Frontends hinzuzufügen, wiederholen Sie die zuvor genannten Schritte. Schauen wir uns an, wie man ein React-Micro-Frontend in dieselbe Root-Konfiguration integriert.

Erstellen Sie ein neues React-Micro-Frontend mit dem folgenden Befehl.

npx create-single-spa --module-type react

Navigieren Sie dann in das erstellte Projekt und installieren Sie single-spa-react.

npm install single-spa-react

Ändern Sie die Eintragsdatei, um Lebenszyklusmethoden zu exportieren, um die App mit Single-Spa kompatibel zu machen.

import React from \\\"react\\\";import ReactDOM from \\\"react-dom\\\";import singleSpaReact from \\\"single-spa-react\\\";import App from \\\"./App\\\";const lifecycles = singleSpaReact({  React,  ReactDOM,  rootComponent: App,  errorBoundary(err, info, props) {    return 
Error loading React micro-frontend
; },});export const { bootstrap, mount, unmount } = lifecycles;

Sobald die Konfigurationen abgeschlossen sind, können wir das React-Micro-Frontend mit dem folgenden Befehl bereitstellen.

npm start

Um das erstellte Mikro-Frontend in die vorhandene Root-Konfiguration zu integrieren, implementieren Sie die folgenden Änderungen an den Dateien in der Root-Konfiguration.

import { registerApplication, start } from \\\"single-spa\\\";registerApplication({  name: \\\"@org/angular-spa-frontend\\\",  app: () =>    System.import(\\\"@org/angular-spa-frontend\\\")      .then((module) => ({        bootstrap: module.bootstrap,        mount: module.mount,        unmount: module.unmount,      }))      .catch((error) => {        console.error(\\\"Failed to load Angular micro-frontend:\\\", error);        return Promise.reject(error);      }),  activeWhen: [\\\"/\\\"],});registerApplication({  name: \\\"@org/react-spa-frontend\\\",  app: () =>    System.import(\\\"@org/react-spa-frontend\\\")      .then((module) => ({        bootstrap: module.bootstrap,        mount: module.mount,        unmount: module.unmount,      }))      .catch((error) => {        console.error(\\\"Failed to load React micro-frontend:\\\", error);        return Promise.reject(error);      }),  activeWhen: [\\\"/react\\\"], });start({  urlRerouteOnly: true,});

Sie müssen außerdem die Datei index.ejs mit dem Hauptpaketpfad der React-App aktualisieren.

GitHub-Referenz

Sehen Sie sich das vollständige Codebeispiel dieser Single-Spa-Anwendung in dieser GitHub-Demo an.

Abschluss

Die Verwendung von Single-Spa zum Erstellen von Mikro-Frontends erleichtert die Aufteilung einer großen App in kleine, unabhängige Teile. Auf diese Weise können verschiedene Teams an ihren Aufgaben arbeiten, ohne andere zu beeinträchtigen, und die von ihnen bevorzugten Frameworks wie Angular oder React verwenden. Wenn Sie die Schritte in dieser Anleitung befolgen, können Sie ein Einzel-Spa-Projekt einrichten, mehrere Mikro-Frontends verbinden und den Benutzern ein reibungsloses Erlebnis bieten. Mit Single-Spa können Sie Ihre App ganz einfach im Laufe der Zeit erweitern und bei Bedarf neue Funktionen hinzufügen.

Verwandte Blogs

","image":"http://www.luping.net/uploads/20250111/173657805567821407db4d2.jpg173657805567821407db4d8.png","datePublished":"2025-01-11T17:54:45+08:00","dateModified":"2025-01-11T17:54:45+08:00","author":{"@type":"Person","name":"luping.net","url":"https://www.luping.net/articlelist/0_1.html"}}
„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Erstellen Sie Micro-Frontends mit Single-Spa: Eine Anleitung

Erstellen Sie Micro-Frontends mit Single-Spa: Eine Anleitung

Veröffentlicht am 11.01.2025
Durchsuche:671

TL;DR: Die Verwendung von Single-Spa zum Erstellen von Mikro-Frontends erleichtert die Aufteilung einer großen App in kleine, unabhängige Teile, sodass verschiedene Teams an Teilen arbeiten können, ohne andere zu beeinträchtigen. Dieser Blog zeigt, wie man Angular- und React-Micro-Frontends erstellt, sie mit einer Root-Konfiguration verbindet und bereitstellt.

Micro Frontends sind zu einem beliebten Architekturstil für die Skalierung von Frontend-Apps geworden, insbesondere wenn mehrere Teams an verschiedenen Teilen einer Benutzeroberfläche arbeiten. Durch die Aufteilung monolithischer Frontends in kleinere, unabhängige Module können Teams Teile einer App separat bereitstellen, aktualisieren und skalieren. In diesem Artikel wird erläutert, wie Sie mithilfe von Single-Spa Mikro-Frontends verschiedener Frameworks erstellen und verbinden.

Einführung in das Single-Spa

Build Micro Frontends with single-spa: A Guide

Single-spa ist ein JavaScript-basiertes Framework, das für die Mikro-Frontend-Architektur entwickelt wurde. Es ermöglicht Ihnen, Mikro-Frontends mit Frameworks wie Angular, React und Vue zu erstellen und diese als eine einzige App bereitzustellen. Es verwaltet ein Register der verbundenen Apps und verwendet Routen, um Benutzer zu verschiedenen Apps umzuleiten.

Build Micro Frontends with single-spa: A Guide

Die Verwendung eines Single-SPA-Frameworks bietet viele Vorteile, z. B. die Auswahl verschiedener Sprachen für verschiedene Teile der App, die unabhängige Entwicklung und Bereitstellung von Mikro-Frontends sowie die Skalierbarkeit. Beginnen wir also mit der Erstellung eines Single-Spa.

Erstellen eines Single-Spa

Voraussetzungen

Um ein Single-Spa zu implementieren, ist es wichtig, dass Node.js und npm installiert sind. Um sie zu installieren, gehen Sie zur Node.js-Website und laden Sie die neueste Version für Ihr Betriebssystem herunter. Führen Sie das Installationsprogramm aus, um die Installation abzuschließen.

Überprüfen Sie dann die Installation von node.js und npm, indem Sie die folgenden Befehle in der Eingabeaufforderung ausführen.

npm - version
node - version

Schritt 1: Einrichten des Projekts

In diesem Beispiel werden zwei einfache Micro-Frontends mit Angular und React erstellt. Eine Root-Konfiguration wird die beiden Mikro-Frontends bedienen.

Erstellen Sie eine App

Wir können eine einfache Angular-Micro-Frontend-App erstellen, indem wir den folgenden Befehl ausführen.

ng new angular-spa-frontend

Sobald das Projekt erstellt wurde, führen Sie den nächsten Befehl aus, um die Single-Spa-Bibliothek zu installieren.

ng add single-spa-angular

Sobald die Bibliothek ordnungsgemäß installiert wurde, wird im Angular-Projekt eine Datei mit dem Namen main.single-spa.ts erstellt, die alle Konfigurationen im Zusammenhang mit single-spa enthält.

Beziehen Sie sich auf den Konfigurationscode.

if (environment.production) {
 enableProdMode();
}

const lifecycles = singleSpaAngular({
 bootstrapFunction: (singleSpaProps) => {
  singleSpaPropsSubject.next(singleSpaProps);

  const extraProviders = [
   ...getSingleSpaExtraProviders(),
   { provide: APP_BASE_HREF, useValue: '/' }
  ];

  return platformBrowserDynamic(extraProviders).bootstrapModule(AppModule);
 },
 template: '',
 Router,
 NavigationStart,
 NgZone,
});

export const bootstrap = lifecycles.bootstrap;
export const mount = lifecycles.mount;
export const unmount = lifecycles.unmount;

Es ist erforderlich, einen APP_BASE_HREF-Wert bereitzustellen, um als Einzel-Spa zu funktionieren.

Darüber hinaus enthält package.json beim Hinzufügen der Single-Spa-Bibliothek zwei zusätzliche Skripte.

"scripts": {
  "ng": "ng",
  "start": "ng serve",
  "build": "ng build",
  "watch": "ng build --watch --configuration development",
  "test": "ng test",
  "build:single-spa:angular-spa-frontend": "ng build angular-spa-frontend --prod",
  "serve:single-spa:angular-spa-frontend": "ng s --project angular-spa-frontend --disable-host-check --port 4200 --live-reload false"
 }

Die Datei angular.json wird mit den folgenden Konfigurationen geändert.

"build": {
   "builder": "@angular-builders/custom-webpack:browser",
   "options": {
      "outputPath": "dist/angular-spa-frontend",
      "index": "src/index.html",
      "main": "src/main.single-spa.ts",
      "polyfills": "src/polyfills.ts",
      "tsConfig": "tsconfig.app.json",
      "inlineStyleLanguage": "scss",
      "assets": [
       "src/favicon.ico",
       "src/assets"
      ],
      "styles": [
       "src/styles.scss"
      ],
      "scripts": [],
      "customWebpackConfig": {
       "path": "extra-webpack.config.js",
       "libraryName": "angular-spa-frontend",
       "libraryTarget": "umd"
      },
      "deployUrl": "http://localhost:4200/"
     },

}

“main“: „src/main.ts“ wird ersetzt durch “main“: „src/main.single-spa.ts“. Eine neue Build-Konfiguration wird als JavaScript-Modul hinzugefügt.

Sobald die Konfigurationen abgeschlossen und überprüft sind, können wir die Angular-App mit dem folgenden Befehl bereitstellen.

npm run serve:single-spa:angular-spa-frontend

Nachdem wir die Micro-Frontend-App erfolgreich erstellt haben, schauen wir uns an, wie die Root-Konfiguration implementiert wird.

Root-Konfiguration

Führen Sie den folgenden Befehl aus, um die Root-Konfiguration zu erstellen.

npx create-single-spa

Bei Eingabe dieses Befehls wird eine Reihe von Konfigurationen angezeigt, um die Root-Konfiguration zu erstellen. Build Micro Frontends with single-spa: A Guide

Nach Auswahl der vorherigen Konfigurationen wird die Root-Konfiguration erstellt, um mehrere Frontends zu bedienen.

Um das erstellte Micro-Frontend mit der Root-Konfiguration zu verbinden, müssen wir die Dateien root-config.ts und index.ejs ändern.

registerApplication({
 name: "@org/angular-spa-frontend",
 app: () =>
  System.import("@org/angular-spa-frontend")
   .then((module: LifeCycles) => ({
    bootstrap: module.bootstrap,
    mount: module.mount,
    unmount: module.unmount,
   }))
   .catch((error) => {
    console.error("Failed to load micro-frontend:", error);
    return Promise.reject(error);
   }),
  activeWhen: ['/'],
});

start({
 urlRerouteOnly: true,
});

Wie im vorherigen Codeblock erwähnt, sollte das erstellte Micro-Frontend in die Datei root-config.ts importiert werden.

name: "@org/angular-spa-frontend",

Die folgenden Skripte sollten zur Datei index.ejs hinzugefügt werden.


 

 

Erstelltes Mikro-Frontend ( @org/angular-spa-frontend ), zusammen mit der URL ( http://localhost:4200/main.js ), in der sich das Mikro befindet Frontend wurde gehostet, muss in der Import-Map hinzugefügt werden.

Führen Sie dann den folgenden Befehl aus, um die App auszuführen.

npm run start

Vorausgesetzt, diese Schritte werden korrekt ausgeführt, sollten wir in der Ansicht das endgültige Einzel-Spa sehen können, ähnlich dem folgenden Bild.

Build Micro Frontends with single-spa: A Guide

Schritt 2: Bereitstellung in der Produktion

Bei der Bereitstellung dieser Mikro-Frontends in der Produktion wird empfohlen, jede Mikro-Frontend-App als unabhängige, eigenständige App bereitzustellen. Die Root-Konfiguration wird vermutlich jede App dynamisch laden, abhängig von den App-Routen, die in der registerApplication festgelegt sind.

Schritt 3: Weitere Mikro-Frontends hinzufügen

Um weitere Mikro-Frontends hinzuzufügen, wiederholen Sie die zuvor genannten Schritte. Schauen wir uns an, wie man ein React-Micro-Frontend in dieselbe Root-Konfiguration integriert.

Erstellen Sie ein neues React-Micro-Frontend mit dem folgenden Befehl.

npx create-single-spa --module-type react

Navigieren Sie dann in das erstellte Projekt und installieren Sie single-spa-react.

npm install single-spa-react

Ändern Sie die Eintragsdatei, um Lebenszyklusmethoden zu exportieren, um die App mit Single-Spa kompatibel zu machen.

import React from "react";
import ReactDOM from "react-dom";
import singleSpaReact from "single-spa-react";
import App from "./App";

const lifecycles = singleSpaReact({
  React,
  ReactDOM,
  rootComponent: App,
  errorBoundary(err, info, props) {
    return 
Error loading React micro-frontend
; }, }); export const { bootstrap, mount, unmount } = lifecycles;

Sobald die Konfigurationen abgeschlossen sind, können wir das React-Micro-Frontend mit dem folgenden Befehl bereitstellen.

npm start

Um das erstellte Mikro-Frontend in die vorhandene Root-Konfiguration zu integrieren, implementieren Sie die folgenden Änderungen an den Dateien in der Root-Konfiguration.

import { registerApplication, start } from "single-spa";

registerApplication({
  name: "@org/angular-spa-frontend",
  app: () =>
    System.import("@org/angular-spa-frontend")
      .then((module) => ({
        bootstrap: module.bootstrap,
        mount: module.mount,
        unmount: module.unmount,
      }))
      .catch((error) => {
        console.error("Failed to load Angular micro-frontend:", error);
        return Promise.reject(error);
      }),
  activeWhen: ["/"],
});

registerApplication({
  name: "@org/react-spa-frontend",
  app: () =>
    System.import("@org/react-spa-frontend")
      .then((module) => ({
        bootstrap: module.bootstrap,
        mount: module.mount,
        unmount: module.unmount,
      }))
      .catch((error) => {
        console.error("Failed to load React micro-frontend:", error);
        return Promise.reject(error);
      }),
  activeWhen: ["/react"], 
});

start({
  urlRerouteOnly: true,
});

Sie müssen außerdem die Datei index.ejs mit dem Hauptpaketpfad der React-App aktualisieren.





GitHub-Referenz

Sehen Sie sich das vollständige Codebeispiel dieser Single-Spa-Anwendung in dieser GitHub-Demo an.

Abschluss

Die Verwendung von Single-Spa zum Erstellen von Mikro-Frontends erleichtert die Aufteilung einer großen App in kleine, unabhängige Teile. Auf diese Weise können verschiedene Teams an ihren Aufgaben arbeiten, ohne andere zu beeinträchtigen, und die von ihnen bevorzugten Frameworks wie Angular oder React verwenden. Wenn Sie die Schritte in dieser Anleitung befolgen, können Sie ein Einzel-Spa-Projekt einrichten, mehrere Mikro-Frontends verbinden und den Benutzern ein reibungsloses Erlebnis bieten. Mit Single-Spa können Sie Ihre App ganz einfach im Laufe der Zeit erweitern und bei Bedarf neue Funktionen hinzufügen.

Verwandte Blogs

  • Asynchrones JavaScript mit RxJS beherrschen
  • Axios und Fetch API? Auswahl des richtigen HTTP-Clients
  • TypeScript-Dienstprogrammtypen: Eine vollständige Anleitung
  • Sicherer JWT-Speicher: Best Practices
Freigabeerklärung Dieser Artikel ist abgedruckt unter: https://dev.to/syncfusion/build-micro-frontends-with-single-spa-a-guide-4aj3?1 Bei Verstößen wenden Sie sich zum Löschen bitte an [email protected] Es
Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3