PDF-Rendering aus React-Komponenten, serverseitig oder im Browser.
@react-pdf/renderer rendert React-Komponenten zu PDFs — server-side (Node) oder client-side. Statt HTML-zu-PDF-Hack (Puppeteer) wird ein eigener Renderer benutzt, der direkt PDF-Primitives ausgibt.
pnpm add @react-pdf/renderer
import { Document, Page, Text, View, StyleSheet, pdf } from '@react-pdf/renderer'
const styles = StyleSheet.create({
page: { padding: 40 },
title: { fontSize: 24, fontWeight: 'bold' }
})
const MyDoc = () => (
<Document>
<Page size="A4" style={styles.page}>
<Text style={styles.title}>Bewerbung</Text>
</Page>
</Document>
)
const blob = await pdf(<MyDoc />).toBlob()
StyleSheet.create statt inline — bessere Perf, Flexbox-Subset.<Font.register> für Custom-Fonts (TTF/OTF mit Unicode-Range).// app/api/cv/route.ts
const stream = await renderToStream(<MyDoc />)
return new Response(stream as any, { headers: { 'Content-Type': 'application/pdf' } })
wrap und break-Props.grid, keine Pseudo-Klassen, kein position: sticky.Font.register → fallback auf Helvetica, oft fehlende Unicode-Glyphen (Umlaute!).Page break ist eigenwillig — wrap={false} auf Container nutzen, wenn nicht trennen.Wenn du bestehendes HTML/CSS als PDF brauchst → Puppeteer / Playwright (Headless-Chrome). Für reine Daten-Tabellen → pdfkit direkt, weniger Overhead.