Heim > Web-Frontend > js-Tutorial > Erstellen und führen Sie Ihr Projekt in Monorepo mit PNPM aus

Erstellen und führen Sie Ihr Projekt in Monorepo mit PNPM aus

Patricia Arquette
Freigeben: 2025-01-19 16:33:12
Original
308 Leute haben es durchsucht

Build and run your project in Monorepo with PNPM

Projektcode-Organisation: Polyrepo vs. Monorepo

Es gibt im Wesentlichen zwei Möglichkeiten, Projektcode zu organisieren:

  1. Polyrepo: Verteilen Sie Projektcode in verschiedenen Repositorys. Dies ist die derzeitige Standardpraxis. Mehrere Teams verfügen über eigene Lager, bauen Produkte und Pipelines und sind autonom.
  2. Monorepo: Zentralisiert den gesamten Projektcode in einem Repository. Projekte sind in Anwendungen und Pakete unterteilt, um die Wiederverwendung von Code zu erleichtern und Standardfunktionen gemeinsam zu nutzen. Dies hilft dabei, Paketversionen von Drittanbietern zu vereinheitlichen, Quellcode für Abhängigkeiten rekursiv zu erstellen und dieselben Tools für CI/CD-Pipelines zu verwenden.

Monorepo wird von vielen großen Technologieunternehmen wie Yandex verwendet. Monorepo hilft beim Austausch von Ideen und Best Practices zwischen Teams und Geschäftsbereichen. Weitere Informationen zu Monorepo und zugehörigen Tools finden Sie unter https://www.php.cn/link/b01ccf4f29b57b0b1bdb9407050db28d. Dieser Artikel konzentriert sich auf eine einfache Lösung zum Erstellen von Monorepo mit PNPM.

PNPM verwendet Arbeitsbereiche, um mehrere Projekte in einem einzigen Repository zu integrieren.

Umgebungseinrichtung

Erstellen Sie zunächst einen leeren Ordner als neues Monorepo-Projekt. PNPM im Lager initialisieren:

<code class="language-bash">pnpm init</code>
Nach dem Login kopieren
Nach dem Login kopieren

Erstellen Sie dann eine pnpm-workspace.yaml-Datei, die den Paketordner beschreibt:

<code class="language-yaml">// pnpm-workspace.yaml

packages:
  - 'packages/**'
  - 'apps/**'</code>
Nach dem Login kopieren
Nach dem Login kopieren
Der Ordner

/packages enthält gemeinsam genutzte Bibliotheken und der Ordner /apps enthält Anwendungen (z. B. eine eigenständige React Native-Mobilanwendung und eine Webanwendung, die dieselbe Komponente oder Verbindungsbibliothek für die Kommunikation mit dem API-Server verwendet).

In diesem Artikel wird ein Telegram-Veröffentlichungsroboter als Beispiel verwendet. Der Quellcode befindet sich auf GitHub: https://www.php.cn/link/8164ca2fe04767628ac1c6813e8a0867. Laden Sie es herunter und extrahieren Sie es in den Ordner /apps/publish-bot. Führen Sie dann den Installationsbefehl aus:

<code class="language-bash">pnpm install</code>
Nach dem Login kopieren
Nach dem Login kopieren

Telegram-Toolkit erstellen

Erstellen Sie einen Ordner mit dem Namen /packages im Ordner telegram-utils und initialisieren Sie PNPM und TypeScript:

<code class="language-bash">pnpm init && pnpm add -D typescript && pnpm tsc --init</code>
Nach dem Login kopieren
Nach dem Login kopieren

Dieses Paket bietet eine Funktion zum Kombinieren von Text und Bildunterschriften aller Nachrichten (Text, Video und Foto). Das Telegraf-Paket muss installiert sein:

<code class="language-bash">pnpm add telegraf</code>
Nach dem Login kopieren
Nach dem Login kopieren

Der gesamte Quellcode sollte sich im Verzeichnis /src befinden. Um die funktionale Gruppierung zu erleichtern, empfiehlt es sich, unterschiedliche Ordner anzulegen. Die Funktion zum Kombinieren von Text befindet sich im Ordner /texts, der Code lautet wie folgt:

<code class="language-typescript">// packages/telegram-utils/src/texts/combineTexts.ts

import { Message } from 'telegraf/types';
import { FmtString, join } from 'telegraf/format';

type GroupedMessages = {
    photos: Array<Message.PhotoMessage>;
    videos: Array<Message.VideoMessage>;
    text: Array<Message.TextMessage>;
};

export const combineTexts = ({ photos, videos, text }: GroupedMessages) => {
    const photoTexts = photos
        .map(photo => photo.caption ? new FmtString(photo.caption, photo.caption_entities) : undefined)
        .filter((t): t is Required<FmtString> => t !== undefined);

    const videoTexts = videos
        .map(video => video.caption ? new FmtString(video.caption, video.caption_entities) : undefined)
        .filter((t): t is Required<FmtString> => t !== undefined);

    const allTexts = [];

    if (text.length) allTexts.push(join(text.map(t => new FmtString(t.text, t.entities))), '\n');
    if (photoTexts.length) allTexts.push(join(photoTexts, '\n'));
    if (videoTexts.length) allTexts.push(join(videoTexts, '\n'));

    return join(allTexts, '\n');
};</code>
Nach dem Login kopieren
Nach dem Login kopieren

Codebeschreibung:

  • Die Funktion gibt Nachrichten gruppiert nach Typ ein: Foto, Video oder Text
  • Mediennachrichten sollten in FMT-Strings konvertiert werden, die Titel und Titelentitäten enthalten. Für die anschließende Filterung sollte undefined zurückgegeben werden;
  • Verketten Sie Textfelder Schritt für Schritt und fassen Sie schließlich alle Texte zu einer großen Nachricht zusammen.
Erstellen Sie eine Indexdatei für den Ordner

: /texts

<code class="language-bash">pnpm init</code>
Nach dem Login kopieren
Nach dem Login kopieren
Verwenden Sie das Feld

in der Datei package.json, um den Export der Paketfunktion einzurichten: exports

<code class="language-yaml">// pnpm-workspace.yaml

packages:
  - 'packages/**'
  - 'apps/**'</code>
Nach dem Login kopieren
Nach dem Login kopieren
Um Monorepo-Pakete in Ihrer Anwendung zu identifizieren, fügen Sie allen Paketen das Präfix

hinzu. Benennen Sie das Paket @monorepo in der Datei package.json um: telegram-utils

<code class="language-bash">pnpm install</code>
Nach dem Login kopieren
Nach dem Login kopieren
Build-Skript hinzufügen:

<code class="language-bash">pnpm init && pnpm add -D typescript && pnpm tsc --init</code>
Nach dem Login kopieren
Nach dem Login kopieren
Vollständige

Datei: package.json

<code class="language-bash">pnpm add telegraf</code>
Nach dem Login kopieren
Nach dem Login kopieren
Konfigurieren Sie den TypeScript-Compiler: Aktivieren Sie die inkrementelle Kompilierung, um Buildzeit zu sparen und nur geänderte Teile zu verarbeiten. Definieren Sie den Ordner

als /src und den Ordner rootDir des Pakets als outDir. Aktualisiert /dist: tsconfig.json

<code class="language-typescript">// packages/telegram-utils/src/texts/combineTexts.ts

import { Message } from 'telegraf/types';
import { FmtString, join } from 'telegraf/format';

type GroupedMessages = {
    photos: Array<Message.PhotoMessage>;
    videos: Array<Message.VideoMessage>;
    text: Array<Message.TextMessage>;
};

export const combineTexts = ({ photos, videos, text }: GroupedMessages) => {
    const photoTexts = photos
        .map(photo => photo.caption ? new FmtString(photo.caption, photo.caption_entities) : undefined)
        .filter((t): t is Required<FmtString> => t !== undefined);

    const videoTexts = videos
        .map(video => video.caption ? new FmtString(video.caption, video.caption_entities) : undefined)
        .filter((t): t is Required<FmtString> => t !== undefined);

    const allTexts = [];

    if (text.length) allTexts.push(join(text.map(t => new FmtString(t.text, t.entities))), '\n');
    if (photoTexts.length) allTexts.push(join(photoTexts, '\n'));
    if (videoTexts.length) allTexts.push(join(videoTexts, '\n'));

    return join(allTexts, '\n');
};</code>
Nach dem Login kopieren
Nach dem Login kopieren

Integration

Gehen Sie zurück zu

und fügen Sie das Paket /apps/publish-bot zu den Abhängigkeiten hinzu. Beachten Sie, dass Sie die Paketversion nicht angeben müssen. Verwenden Sie @monorepo/telegram-utils, um Folgendes anzugeben: workspace:*

<code class="language-typescript">// packages/telegram-utils/src/texts/index.ts

export * from './combineTexts';</code>
Nach dem Login kopieren
Abhängigkeiten installieren:

<code class="language-json">// packages/telegram-utils/package.json

"exports": {
    "./texts": {
        "import": "./src/texts/index.ts",
        "require": "./dist/texts/index.js"
    }
}</code>
Nach dem Login kopieren
Aktualisieren Sie den Befehl

zum Veröffentlichen von Bots: preview

<code class="language-json">// packages/telegram-utils/package.json

"name": "@monorepo/telegram-utils"</code>
Nach dem Login kopieren
Update

: /apps/publish-bot/tsconfig.json

<code class="language-json">// packages/telegram-utils/package.json

"scripts": {
    "build": "tsc -p tsconfig.json"
}</code>
Nach dem Login kopieren
Bevor Sie den Anwendungscode erstellen, müssen Sie alle Abhängigkeiten erstellen:

<code class="language-json">// packages/telegram-utils/package.json

{
    "name": "@monorepo/telegram-utils",
    "version": "1.0.0",
    "main": "index.js",
    "scripts": {
        "build": "tsc -p tsconfig.json"
    },
    "keywords": [],
    "license": "ISC",
    "exports": {
        "./texts": {
            "import": "./src/texts/index.ts",
            "require": "./dist/texts/index.js"
        }
    },
    "devDependencies": {
        "typescript": "^5.7.3"
    },
    "dependencies": {
        "telegraf": "^4.16.3"
    }
}</code>
Nach dem Login kopieren

Zusammenfassung

Der Release-Bot verwendet jetzt interne gemeinsam genutzte Bibliotheken/Pakete und befindet sich in Monorepo. Dadurch ist es möglich, schnell neue Funktionen zu erstellen und Code in mehreren Anwendungen wiederzuverwenden.

Bild von Gabriel Heinzer auf Unsplash

Das obige ist der detaillierte Inhalt vonErstellen und führen Sie Ihr Projekt in Monorepo mit PNPM aus. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage