node实现,下载html、pdf、html(html转word、pdf)

最近项目接到需求,要求下载html、word、pdf的文件,特此记录
前端:react(antd)
后端:node
包:jsdom、html-pdf、html-docx-js

<Button onClick={() => exportDownload('/后端处理api, {其他筛选逻辑}, '前端文件名');>下载</Button>
exportDownload () {
  其他筛选逻辑处理
  
  const downloadUrl = `后端文件处理api`;
  const a = document.createElement('a');
  a.href = downloadUrl;
  a.download = 前端文件名;
  a.style.display = 'none';
  document.body.appendChild(a);
  a.click();
  document.body.removeChild(a);
} 

后端api
我们的html直接是字符串拼接起来的,变量htmlString为我们拼接的字符串
	  // 导出html
      const html = '<html><body>' + itemThtml + '</body></html>';
      ctx.body = html;
      type = 'html';
      ctx.set('content-type', 'application/octet-stream');
      // 导出word
      const docx = HtmlDocx.asBlob(html);
      ctx.body = docx;
      type = 'docx';
      ctx.set('content-type', 'application/msword');
      // 导出pdf
      const data = await new Promise((res, rej) => {
        pdf.create(html, {format: 'A4'}).toBuffer((err, buffer) => {
          if (err) rej(err);
          res(buffer);
        });
      });
      type = 'pdf';
      ctx.body = data;
      ctx.set('content-type', 'application/pdf');

注:

  1. html中的canvas元素不能直接在word中显示,所以用JSDOM转成base64的图片,然后插入图片 const dom = new JSDOM(${HtmlString}, { runScripts: 'dangerously' });
  2. 转换之后在不同分辨率的wps中显示不同,但是在word中样式基本一致
  3. 筛选逻辑那里涉及数据库时间的:// 把客户端本地的 utc偏移量传给后端,后端才能把导出的时间变成客户端的本地时间 utcOffset: moment().utcOffset(),
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Node.js 是一种在服务器端运行的 JavaScript 运行环境,可以用于实现各种各样的应用程序。而 LibreOffice 是一款免费、开源的办公软件套件,其中包括了 Writer、Calc、Impress 等应用程序,支持多种文档格式。下面是一个基于 Node.js 和 LibreOffice 的实现 Word PDF 的简单方法: 1.安装 LibreOffice:首先需要在服务器上安装 LibreOffice,可以通过命令行或者图形界面进行安装。 2.使用 Node.js 的 child_process 模块:在 Node.js 中可以通过 child_process 模块来执行系统命令,在本例中可以使用该模块执行 LibreOffice 的命令行工具来进行 Word PDF 的操作。 3.编写 Node.js 代码:可以通过 Node.js 编写一个简单的脚本来实现 Word PDF。以下是一个简单的示例代码: ```javascript const { spawn } = require('child_process'); const inputFilePath = '/path/to/input.docx'; const outputFilePath = '/path/to/output.pdf'; const libreoffice = spawn('libreoffice', [ '--headless', '--convert-to', 'pdf', inputFilePath, '--outdir', outputFilePath, ]); libreoffice.stdout.on('data', (data) => { console.log(`stdout: ${data}`); }); libreoffice.stderr.on('data', (data) => { console.error(`stderr: ${data}`); }); libreoffice.on('close', (code) => { console.log(`child process exited with code ${code}`); }); ``` 以上代码中,spawn 方法会启动一个新的进程来执行 LibreOffice 命令行工具。'--headless' 参数表示以无头模式运行,'--convert-to pdf' 参数表示换成 PDF 格式,inputFilePath 参数表示输入文件的路径,'--outdir' 参数表示输出文件的路径。 4.运行 Node.js 代码:在终端中运行 Node.js 脚本即可进行 Word PDF 的操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值