ホームページ > 記事 > ウェブフロントエンド > Nodejsを使用してHTMLをPDFに変換する
インターネット技術の継続的な発展に伴い、共有やダウンロードを容易にするために、Web コンテンツを PDF 形式に変換する必要があるアプリケーションがますます増えています。このプロセスでは、Node.js を HTML ドキュメントを PDF 形式に変換する強力なツールとして使用できます。この記事では、Node.js を使用して HTML を PDF に変換するプロセスについて説明します。
始める前に、次の必要なパッケージをシステムにインストールする必要があります:
Wkhtmltopdf は WebKit エンジンをベースにしたコマンドです。 HTML ドキュメントを PDF ファイルに変換できるオンライン ツールで、透かし、ヘッダーとフッター、その他多くの機能の追加もサポートしています。
Ubuntu システムでは、次のコマンドで wkhtmltopdf をインストールできます:
sudo apt-get install wkhtmltopdf
次に、pdfkit と fs モジュールをインストールする必要があります。 、どちらも npm パッケージ マネージャーを通じてインストールできます。
コマンド ラインに次のコマンドを入力してインストールします:
npm install pdfkit
npm install fs
関連する依存関係をインストールした後、JavaScript コードの記述を開始できます。 。 「html-to-pdf.js」という名前のファイルを作成し、次のコードを記述します:
const pdfkit = require('pdfkit'); const fs = require('fs'); const wkhtmltopdf = require('wkhtmltopdf'); // 生成 PDF function generatePDF(html, options, callback) { // 创建文件流 const inputStream = fs.createReadStream(html); // 调用 wkhtmltopdf wkhtmltopdf(inputStream, options, (error, stream) => { if (error) { callback(error); } else { callback(null, stream); } }); } // 写 PDF function writePDF(doc, path, callback) { const writeStream = fs.createWriteStream(path); writeStream.on('error', (error) => { callback(error); }); doc.pipe(writeStream); doc.end(); } // 创建 PDF function createPDF(html, path, options, callback) { const doc = new pdfkit(); generatePDF(html, options, (error, stream) => { if (error) { callback(error); } else { doc.on('pageAdded', () => { doc.image(stream, { fit: [doc.page.width - 100, doc.page.height - 100], align: 'center', valign: 'center' }); }); doc.pipe(fs.createWriteStream(path)); doc.end(); callback(null, path); } }); } // 导出模块 module.exports = { createPDF, writePDF, generatePDF };
このコードでは、pdfkit、fs、および wkhtmltopdf モジュールを導入し、generatePDF、writePDF、および 3 つの関数を記述しました。 PDFを作成します。
generatePDF 関数は、HTML ファイルを PDF 形式に変換するために使用されます。 HTML、オプション、コールバックの 3 つのパラメータを渡す必要があります。
writePDF 関数は、PDF ドキュメントをファイル システムに書き込むために使用されます。 doc、path、callback という 3 つのパラメータを渡す必要があります。
createPDF 関数はプロセス全体のコントロール センターであり、generatePDF 関数と writePDF 関数を呼び出して、HTML から PDF への変換プロセスを完了できます。
コードの作成が完了したので、Node.js を使用して HTML から PDF への変換を開始できます。コマンド ラインに次のコマンドを入力できます:
node html-to-pdf.js
または、このモジュールを独自のプロジェクトで使用することもできます:
const htmlToPdf = require('./html-to-pdf'); htmlToPdf.createPDF('test.html', 'test.pdf', { pageSize: 'letter', marginTop: '0mm', marginBottom: '0mm', marginLeft: '0mm', marginRight: '0mm' }, (err, result) => { if (err) { console.error(err); return; } console.log('File saved to: ' + result); });
この例では、createPDF 関数を使用して をテストします。 html は、ページ サイズと余白が設定された test.pdf に変換されます。
この記事では、Node.js を使用して HTML を PDF に変換する方法を紹介しました。具体的な手順には、依存関係のインストール、コードの作成、Node の使用が含まれます変換などのための .js。広範な HTML 変換タスクを処理する必要がある場合、Node.js を使用すると、効率的で柔軟かつスケーラブルなソリューションが提供されます。
以上がNodejsを使用してHTMLをPDFに変換するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。