# 导出word
# 依赖
docxtemplater 根据模板填充数据导出WORD文档的库
jszip-utils 读取WORD文件的库
pizzip 一个同步压缩文件的库
open-docxtemplater-image-module 开源WORD插入图片的库
1
2
3
4
2
3
4
//-- 安装 docxtemplater pizzip
npm install docxtemplater pizzip --save
//-- 安装 jszip-utils
npm install jszip-utils --save
//安装 open-docxtemplater-image-module
npm install open-docxtemplater-image-module --save
1
2
3
4
5
6
2
3
4
5
6
import docxtemplater from 'docxtemplater' //生成WORD
import PizZip from 'pizzip'
import JSZipUtils from 'jszip-utils'
const ImageModule = require('open-docxtemplater-image-module'); //WORD图片依赖
1
2
3
4
2
3
4
# 数据填充
数据使用{变量}
图片使用{%变量}
list使用{#list}{data1}{/list}
let data = {
title : '标题',
clients: [
{
first_name: "John",
last_name: "Doe",
phone: "+44546546454"
}
]
img : ''
}
1
2
3
4
5
6
7
8
9
10
11
2
3
4
5
6
7
8
9
10
11
输出文档:
# 导出PDF
Electron 中的 browser window
模块具有 webContents
属性, 它允许您的应用程序进行打印以及打印到PDF.
示例
const { BrowserWindow } = require('electron')
const fs = require('fs')
const path = require('path')
const os = require('os')
const win = new BrowserWindow({ width: 800, height: 600 })
win.loadURL('http://github.com')
win.webContents.on('did-finish-load', () => {
// Use default printing options
win.webContents.printToPDF({}).then(data => {
const pdfPath = path.join(os.homedir(), 'Desktop', 'temp.pdf')
fs.writeFile(pdfPath, data, (error) => {
if (error) throw error
console.log(`Wrote PDF successfully to ${pdfPath}`)
})
}).catch(error => {
console.log(`Failed to write PDF to ${pdfPath}: `, error)
})
})
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20