react-pdf

使用React创建PDF文件。(Create PDF files using React.)

  • Owner: diegomura/react-pdf
  • Platform: Linux, Mac, Windows, BSD, Cross-platform, Solaris, Unix-like
  • License:: MIT License
  • Category::
  • Topic:
  • Like:
    0
      Compare:

Github stars Tracking Chart

用于在浏览器、移动设备和服务器上创建PDF文件的React渲染器。

如何安装

 yarn add @react-pdf/renderer

工作原理

import React from 'react';
import { Document, Page, Text, View, StyleSheet } from '@react-pdf/renderer';

// Create styles
const styles = StyleSheet.create({
  page: {
    flexDirection: 'row',
    backgroundColor: '#E4E4E4'
  },
  section: {
    margin: 10,
    padding: 10,
    flexGrow: 1
  }
});

// Create Document Component
const MyDocument = () => (
  <Document>
    <Page size="A4" style={styles.page}>
      <View style={styles.section}>
        <Text>Section #1</Text>
      </View>
      <View style={styles.section}>
        <Text>Section #2</Text>
      </View>
    </Page>
  </Document>
);

Web. 在DOM中呈现

import React from 'react';
import ReactDOM from 'react-dom';

ReactDOM.render(<MyDocument />, document.getElementById('root'));

Node. 保存在文件中

import React from 'react';
import ReactPDF from '@react-pdf/renderer';

ReactPDF.render(<MyDocument />, `${__dirname}/example.pdf`);

Native. 在手机中呈现

即将推出

示例

对于每个示例,请尝试打开 output.pdf 以查看结果。

要运行这些示例,首先克隆该项目并安装依赖项:

git clone https://github.com/diegomura/react-pdf.git
cd react-pdf
yarn install

然后,运行 yarn example - &lt; example-name&gt;

 yarn example -- fractals

贡献者

这个项目的存在要感谢所有贡献的人。 [贡献]

赞助商

感谢所有赞助商![成为sponsors](https://opencollective.com/react-pdf#sponsors)

支持者

谢谢你们所有的支持者! [成为支持者](https://opencollective.com/react-pdf#backer)

许可证

麻省理工学院© Diego Muracciole

Main metrics

Overview
Name With Ownerdiegomura/react-pdf
Primary LanguageTypeScript
Program languageJavaScript (Language Count: 5)
PlatformLinux, Mac, Windows, BSD, Cross-platform, Solaris, Unix-like
License:MIT License
所有者活动
Created At2016-10-18 21:33:58
Pushed At2025-09-23 21:28:42
Last Commit At2025-09-23 23:24:18
Release Count759
Last Release Name@react-pdf/types@2.9.1 (Posted on 2025-09-23 21:28:42)
First Release Namev0.2.0 (Posted on 2017-06-21 23:12:36)
用户参与
Stargazers Count16.1k
Watchers Count103
Fork Count1.3k
Commits Count1.1k
Has Issues Enabled
Issues Count2005
Issue Open Count417
Pull Requests Count749
Pull Requests Open Count23
Pull Requests Close Count185
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private

How to install

yarn add @react-pdf/renderer

How it works

import React from 'react';
import { Document, Page, Text, View, StyleSheet } from '@react-pdf/renderer';

// Create styles
const styles = StyleSheet.create({
  page: {
    flexDirection: 'row',
    backgroundColor: '#E4E4E4'
  },
  section: {
    margin: 10,
    padding: 10,
    flexGrow: 1
  }
});

// Create Document Component
const MyDocument = () => (
  <Document>
    <Page size="A4" style={styles.page}>
      <View style={styles.section}>
        <Text>Section #1</Text>
      </View>
      <View style={styles.section}>
        <Text>Section #2</Text>
      </View>
    </Page>
  </Document>
);

Web. Render in DOM

import React from 'react';
import ReactDOM from 'react-dom';
import { PDFViewer } from '@react-pdf/renderer';

const App = () => (
  <PDFViewer>
    <MyDocument />
  </PDFViewer>
);

ReactDOM.render(<App />, document.getElementById('root'));

Node. Save in a file

import React from 'react';
import ReactPDF from '@react-pdf/renderer';

ReactPDF.render(<MyDocument />, `${__dirname}/example.pdf`);

Examples

For each example, try opening output.pdf to see the result.

To run the examples, first clone the project and install the dependencies:

git clone https://github.com/diegomura/react-pdf.git
cd react-pdf
yarn install

Then, run yarn example -- <example-name>

yarn example -- fractals

Contributors

This project exists thanks to all the people who contribute. (CONTRIBUTING.md).

Sponsors

Thank you to all our sponsors! [Become a sponsors]

Backers

Thank you to all our backers! [Become a backer]

License

MIT © Diego Muracciole

FOSSA Status