WMP Sites

Mit Node.js HTML in PDF umwandeln: Einfache und effektive Lösungen

Lukas Fuchs vor 2 Jahren JavaScript 3 Min. Lesezeit

Node.js-Module für die HTML-zu-PDF-Konvertierung

Um HTML in PDF umzuwandeln, kannst du verschiedene Node.js-Module nutzen. Jedes Modul hat seine eigenen Vor- und Nachteile. Hier sind einige der beliebtesten Optionen:

puppeteer

Beschreibung: Puppeteer ist ein von Google entwickelter Headless-Browser, der es dir ermöglicht, Webseiten wie ein echter Browser zu rendern. Er bietet eine umfassende API zur Steuerung der Browser-Aktivitäten, einschließlich der PDF-Generierung.

Vorteile:

  • Es ist einfach zu bedienen und erfordert keine zusätzlichen Abhängigkeiten.
  • Es rendert Webseiten präzise, einschließlich aller Elemente wie Bilder, Schriftarten und Tabellen.
  • Bietet erweiterte Optionen für die PDF-Anpassung, wie z. B. Seitenränder, Kopf- und Fußzeilen.

html-pdf

Beschreibung: Html-pdf ist ein leichtgewichtiges Modul, das HTML mithilfe von wkhtmltopdf in PDF umwandelt. Wkhtmltopdf ist ein externes Dienstprogramm, das auf deinem System installiert sein muss.

Vorteile:

  • Schnelle und effiziente Konvertierungen.
  • Unterstützt eine Vielzahl von HTML-Elementen und CSS-Stilen.
  • Bietet grundlegende Optionen für die PDF-Anpassung, wie z. B. Seitenausrichtung und Papierformat.

pdfkit

Beschreibung: Pdfkit ist eine Low-Level-Bibliothek zur Generierung von PDFs von Grund auf. Sie bietet eine umfangreiche API, mit der du benutzerdefinierte PDF-Dokumente erstellen kannst.

Vorteile:

  • Volle Kontrolle über den PDF-Inhalt und das Layout.
  • Ermöglicht die dynamische Generierung von PDFs mit Daten aus anderen Quellen.
  • Unterstützt mehrere Streaming-Formate, einschließlich JPEG, PNG und SVG.

*Auswahl des richtigen Moduls

Die Wahl des richtigen Moduls hängt von deinen spezifischen Anforderungen ab. Wenn du nach einer einfachen und sofort einsatzbereiten Lösung suchst, ist Puppeteer eine gute Option. Html-pdf eignet sich für grundlegende Konvertierungen, während Pdfkit maximale Flexibilität und Kontrolle bietet.

Schritt-für-Schritt-Anleitung zur Konvertierung von HTML zu PDF

Installation der benötigten Pakete

Installiere zunächstä die benötigten Node.js-Module über npm:

npm install html-pdf

Erstelle ein HTML-Dokument

Erstelle ein HTML-Dokument mit dem Inhalt, den du in PDF konvertieren möchtest.

Importiere das Modul und lade das HTML

Importiere das html-pdf-Modul in deine Node.js-Datei und lade das HTML-Dokument, das du konvertieren möchtest:

const htmlPdf = require('html-pdf');
const fs = require('fs');

const html = fs.readFileSync('document.html', 'utf8');

Konvertiere HTML zu PDF

Konvertiere nun das HTML in PDF, indem du die create-Methode des Moduls aufrufst:

htmlPdf.create(html).toFile('document.pdf', function(err, res) {
  if (err) {
    return console.log(err);
  }
  console.log('Das PDF wurde erfolgreich erstellt!');
});

Zusätzliche Optionen

Die create-Methode bietet zusätzliche Optionen zur Anpassung des generierten PDFs:

  • Seitenformat (z.B. A4, Letter)
  • Seitenränder
  • Ausrichtung
  • Kopf- und Fußzeilen
  • Sicherheitseinstellungen

Beispiel:

const options = {
  format: 'A4',
  marginLeft: '20mm',
  marginRight: '20mm',
  header: {
    height: '15mm',
    contents: '<p align="center">Mein PDF-Header</p>'
  },
  footer: {
    height: '10mm',
    contents: '<p align="center">Seite {page} von {pages}</p>'
  }
};

htmlPdf.create(html, options).toFile('document.pdf', function(err, res) {
  ...
});

Anpassung der PDF-Ausgabe (Seitenränder, Kopf- und Fußzeilen)

Nachdem du dein HTML in PDF konvertiert hast, kannst du die Ausgabe an deine spezifischen Anforderungen anpassen. Dies umfasst die Einstellung der Seitenränder sowie das Hinzufügen von Kopf- und Fußzeilen.

Seitenränder festlegen

Mit Node.js-Modulen wie html-pdf oder pdfkit kannst du die Seitenränder deines PDFs anpassen. Die folgende Syntax zeigt, wie du die Ränder in Millimetern festlegst:

pdf.margins({
  top: 10,
  right: 15,
  bottom: 20,
  left: 10
});

Kopf- und Fußzeilen hinzufügen

Kopf- und Fußzeilen können deinem PDF zusätzliche Informationen wie Seitenzahlen oder Unternehmenslogos hinzufügen. Mit html-pdf kannst du Kopf- und Fußzeilen folgendermaßen hinzufügen:

pdf.header('<p>Beispiel-Kopfzeile</p>');
pdf.footer('<p>Beispiel-Fußzeile <%= page %> von <%= totalPages %></p>');

Wenn du zusätzliche Kontrolle über die Gestaltung deiner Kopf- und Fußzeilen benötigst, kannst du stattdessen die pdfkit-Bibliothek verwenden.

Weitere Anpassungsoptionen

Zusätzlich zu Seitenrändern und Kopf- und Fußzeilen kannst du mit Node.js-Modulen wie html-pdf und pdfkit weitere Aspekte der PDF-Ausgabe anpassen, darunter:

  • Seitenformat: Wähle A4, Letter oder ein benutzerdefiniertes Format.
  • Ausrichtung: Lege die Ausrichtung des Inhalts auf Hoch- oder Querformat fest.
  • Schriftarten: Einbetten benutzerdefinierter Schriftarten oder Verwenden von Standardschriftarten.
  • Wasserzeichen: Füge deinem PDF ein Wasserzeichen hinzu, um es vor unbefugter Verwendung zu schützen.

Behandlung von Bildern und externen Ressourcen

Beim Konvertieren von HTML zu PDF musst du auch die Einbindung von Bildern und externen Ressourcen wie CSS-Dateien und JavaScript-Skripten berücksichtigen. Hier sind einige wichtige Überlegungen:

Bilder

  • Lokale Bilder einbetten: Verwende die file://-URL, um lokale Bilder in dein HTML einzubetten. Beispiel: <img src="file:///path/to/image.png">.
  • Remote-Bilder herunterladen: Wenn deine Bilder auf einem Remote-Server liegen, musst du sie lokal herunterladen und in dein HTML einbetten, bevor du die Konvertierung durchführst. Du kannst Bibliotheken wie axios oder fetch verwenden, um Remote-Ressourcen abzurufen.
  • Bildgröße anpassen: Du kannst die Größe der eingebetteten Bilder mithilfe von CSS oder den Optionen des PDF-Konverters anpassen. Auf diese Weise kannst du die Dateigröße der PDF-Datei reduzieren oder Bilder an eine bestimmte Größe anpassen.

Externe Ressourcen

  • CSS-Dateien einbinden: Verwende das <link>-Tag, um externe CSS-Dateien in dein HTML einzubinden. Beispiel: <link href="style.css" rel="stylesheet">.
  • JavaScript-Skripte einbinden: Du kannst JavaScript-Skripte mithilfe des <script>-Tags einbinden. Beispiel: <script src="script.js"></script>.
  • Abhängigkeiten verwalten: Falls du externe Ressourcen wie Schriftarten oder Bibliotheken benötigst, musst du sicherstellen, dass diese ebenfalls in die PDF-Datei eingebettet werden. Verwende Bibliotheken wie html-pdf oder wkhtmltopdf, die die Einbettung externer Ressourcen unterstützen.

Automatisierung der HTML-zu-PDF-Konvertierung

Die Automatisierung der HTML-zu-PDF-Konvertierung bietet zahlreiche Vorteile, etwa eine verbesserte Effizienz und eine reduzierung des manuellen Arbeitsaufwands. In diesem Abschnitt erfährst du, wie du mit Node.js die HTML-zu-PDF-Konvertierung automatisieren kannst.

Warteschlangensysteme

Eine gängige Methode zur Automatisierung ist die Verwendung von Warteschlangensystemen. Diese Systeme, wie z. B. RabbitMQ, verarbeiten asynchron eingehende Konvertierungsanforderungen. Du kannst HTML-Dateien in die Warteschlange einreihen und einen Hintergrundprozess einrichten, der die Konvertierungen verarbeitet und die PDF-Dateien speichert.

Geplante Aufgaben

Du kannst auch geplante Aufgaben verwenden, um die HTML-zu-PDF-Konvertierung zu automatisieren. Bibliotheken wie Node-Cron ermöglichen es dir, Jobs zu bestimmten Zeitpunkten oder Intervallen einzuplanen. So kannst du beispielsweise jeden Tag um Mitternacht HTML-Dateien konvertieren.

Webhooks

Wenn deine HTML-Dateien über Webhooks aktualisiert werden, kannst du einen Serverless-Ansatz verwenden, um die Konvertierung zu automatisieren. Du kannst Dienste wie AWS Lambda oder Google Cloud Functions verwenden, um Funktionen einzurichten, die HTML-Aktualisierungen abfangen und die Konvertierung auslösen.

Integration mit CMS

Wenn du ein Content-Management-System (CMS) verwendest, kannst du dessen API nutzen, um die HTML-zu-PDF-Konvertierung zu automatisieren. Du kannst beispielsweise einen Auslöser erstellen, der eine Konvertierung startet, wenn eine neue HTML-Seite veröffentlicht wird.

Vorteile der Automatisierung

  • Effizienzsteigerung: Automatisierung spart Zeit und reduziert den manuellen Arbeitsaufwand.
  • Verbesserte Genauigkeit: Automatisierte Prozesse sind in der Regel genauer als manuelle Prozesse.
  • Skalierbarkeit: Warteschlangensysteme und geplante Aufgaben ermöglichen die Skalierung der Konvertierungen je nach Bedarf.
  • Zuverlässigkeit: Automatisierte Prozesse sind in der Regel zuverlässiger als manuelle Prozesse.
  • Integration: Die Integration mit CMS und anderen Systemen ermöglicht einen nahtlosen Workflow.

Fehlerbehebung bei häufigen Problemen

Bei der Konvertierung von HTML zu PDF können verschiedene Probleme auftreten. Hier findest du einige Tipps zur Fehlerbehebung für gängige Stolpersteine:

Fehlende oder ungültige HTML-Dokumente

  • Überprüfe, ob du das richtige HTML-Dokument angibst: Stelle sicher, dass der Dateipfad zum Ziel-HTML-Dokument korrekt ist.
  • Überprüfe die Syntax deines HTML-Dokuments: Stelle sicher, dass dein HTML-Dokument gut geformt ist und keine Syntaxfehler enthält. Du kannst Tools wie den HTML-Validator verwenden, um mögliche Probleme zu identifizieren.

Probleme mit Bildern oder externen Ressourcen

  • Überprüfe die URLs deiner Bilder und externen Ressourcen: Stelle sicher, dass die URLs korrekt sind und dass die Ressourcen zugänglich sind.
  • Verwende absolute URLs: Verwende absolute URLs für Bilder und externe Ressourcen, um sicherzustellen, dass sie auch beim Konvertieren in PDF korrekt aufgelöst werden.

Probleme mit der PDF-Ausgabe

  • Überprüfe die Seitengröße und Ausrichtung: Stelle sicher, dass die angegebene Seitengröße und Ausrichtung mit dem gewünschten PDF-Layout übereinstimmen.
  • Passe die Seitenränder an: Passe die Seitenränder an, um sicherzustellen, dass der PDF-Inhalt nicht abgeschnitten wird.
  • Überprüfe die Kopf- und Fußzeilen: Stelle sicher, dass die Kopf- und Fußzeilen wie erwartet angezeigt werden.

Konvertierungsprobleme

  • Überprüfe die verwendeten Node.js-Module: Vergewissere dich, dass du die neuesten Versionen der für die Konvertierung verwendeten Node.js-Module verwendest.
  • Aktualisiere deine Node.js-Version: Stelle sicher, dass du die neueste Version von Node.js verwendest, da ältere Versionen möglicherweise nicht alle Funktionen der Konvertierungsmodule unterstützen.
  • Überprüfe die Verfügbarkeit von Ressourcen: Stelle sicher, dass dein System über genügend Speicher und CPU-Ressourcen verfügt, um die Konvertierung durchzuführen.

Weitere Beiträge

Folge uns

Neue Beiträge

Frontend

Word doppelseitig formatieren: Tipps und Anleitungen für optimales Drucken

AUTOR • May 12, 2026
DevOps & Deployment

TTYs in Linux: Ein umfassender Überblick

AUTOR • May 12, 2026
DevOps & Deployment

Google Drive für Linux: Ein umfassender Leitfaden zur Verwendung und Installation

AUTOR • May 12, 2026
DevOps & Deployment

Linux Mint Themes: Personalisieren Sie Ihren Desktop

AUTOR • May 12, 2026
DevOps & Deployment

youtubedl: Der ultimative Leitfaden zum Herunterladen von YouTube-Videos

AUTOR • May 12, 2026
Frontend

HTML in PowerPoint einbetten: Eine Schritt-für-Schritt-Anleitung

AUTOR • May 12, 2026
Frontend

Alle Querverweise in Word aktualisieren: Ein umfassender Leitfaden

AUTOR • May 12, 2026
DevOps & Deployment

Linux Mint in VirtualBox installieren und konfigurieren

AUTOR • May 12, 2026
API & Webservices

Linux DNS-Cache leeren: Ein umfassender Leitfaden

AUTOR • May 12, 2026
DevOps & Deployment

Linux auf dem iPad: Eine umfassende Anleitung

AUTOR • May 12, 2026
DevOps & Deployment

Mounten von ISO-Images unter Linux: Eine Schritt-für-Schritt-Anleitung

AUTOR • May 12, 2026
DevOps & Deployment

Sortierung von Dateien nach Größe mit dem Befehl "ls" in Linux

AUTOR • May 12, 2026
DevOps & Deployment

Spacedesk für Linux: Erweitere deinen Desktop auf mehrere Geräte

AUTOR • May 12, 2026
DevOps & Deployment

pCloud für Linux: Synchronisieren, Teilen und Sichern Ihrer Dateien

AUTOR • May 12, 2026
DevOps & Deployment

Die Eleganz und Macht von i3wm: Ein minimalistischer Window-Manager für Experten

AUTOR • May 12, 2026
DevOps & Deployment

Bash tr-Befehl: Zeichen suchen, ersetzen und löschen

AUTOR • May 12, 2026
JavaScript

UTF-8 in ANSI umwandeln: Eine Schritt-für-Schritt-Anleitung

AUTOR • May 12, 2026
DevOps & Deployment

Rufus-Alternativen: Die besten Werkzeuge zum Erstellen bootfähiger USB-Laufwerke

AUTOR • May 12, 2026
DevOps & Deployment

Netzwerkadapter unter Linux anzeigen: Eine Schritt-für-Schritt-Anleitung

AUTOR • May 12, 2026
DevOps & Deployment

rpm install: Installation von RPM-Paketen in Linux-Systemen

AUTOR • May 12, 2026

Beliebte Beiträge

DevOps & Deployment

PDF-Komprimierung unter Linux: So reduzieren Sie die Dateigröße Ihrer PDF-Dokumente

AUTOR • May 06, 2024
DevOps & Deployment

Linux Verknüpfungen erstellen: Schritt-für-Schritt-Anleitung

AUTOR • May 06, 2024
DevOps & Deployment

AutoCAD unter Linux: Installationshandbuch und nützliche Tipps

AUTOR • May 06, 2024
DevOps & Deployment

Linux Bildbetrachter: Übersicht, Funktionen und Auswahl des besten Tools

AUTOR • May 06, 2024
Frontend

CSS-Generator: Effortlose Erstellung von benutzerdefinierten Stylesheets

AUTOR • Jul 25, 2024
DevOps & Deployment

Fortnite auf Linux: Wie man das beliebte Battle-Royale-Spiel auf GNU/Linux spielt

AUTOR • May 06, 2024
DevOps & Deployment

So ändern Sie einfach Ihr Passwort in Linux Mint

AUTOR • May 06, 2024
DevOps & Deployment

Linux ISO-Dateien auf USB-Laufwerk erstellen: Eine Schritt-für-Schritt-Anleitung

AUTOR • May 06, 2024
Frontend

Bilder-Upload in HTML: Eine umfassende Anleitung

AUTOR • Apr 24, 2024
DevOps & Deployment

ESP32 Linux: Integration eines leistungsstarken Betriebssystems in Ihr Embedded-Projekt

AUTOR • May 06, 2024
DevOps & Deployment

Kali Linux Update: Schritt-für-Schritt-Anleitung zur Aktualisierung Ihres Systems

AUTOR • May 06, 2024
DevOps & Deployment

Ulimit: Der ultimative Leitfaden zum Verwalten von Prozessressourcen

AUTOR • May 09, 2024
DevOps & Deployment

DEB-Dateien in Linux installieren: Eine umfassende Anleitung

AUTOR • May 06, 2024
DevOps & Deployment

Teilen von Dateien unter Linux: Der Befehl 'split'

AUTOR • May 06, 2024
DevOps & Deployment

Linux-Deinstallation: Schritt-für-Schritt-Anleitung zum Entfernen von Linux

AUTOR • May 06, 2024
DevOps & Deployment

Linux Mint und Snap: Eine umfassende Anleitung zur Paketverwaltung

AUTOR • May 06, 2024
DevOps & Deployment

Python-Version prüfen: So ermitteln Sie die aktuelle Version

AUTOR • May 06, 2024
DevOps & Deployment

Sway Window Manager: Eine schlanke und benutzerfreundliche Wahl

AUTOR • May 06, 2024
Frontend

Beschleunigen Sie die Dateneingabe mit HTML Datalist

AUTOR • Jul 27, 2024
Frontend

Videos auf voller Bildschirmgröße in HTML einbetten: Schritt-für-Schritt-Anleitung

AUTOR • Apr 24, 2024