前端:纯前端快速实现html导出word和pdf

实现html导出word,需要使用两个库。 html-docx-js和file-saver

导出word的js方法

> npm install html-docx-js

>npm install file-saver

js引入

import FileSaver from "file-saver";

import htmlDocx from "html-docx-js/dist/html-docx";

/**导出word方法 */

exportWord() {

let contentHtml = document.getElementById("myContainer").innerHTML;

//myContainer是需要导入的dom元素的id,也就是像

let content = `

${contentHtml}
\`;

console.log(content)

let converted = htmlDocx.asBlob(content);//利用插件转

FileSaver.saveAs(converted, "xxx.docx");//导出为word,要以.docx为后缀,xxxx可任意名字

},

要注意的点及推荐:

1:要导出word的html代码不推荐使用组件,例如等,bug很多,最好使用原始的html代码。但是像v-model这种数据绑定的都是可以用的

2:表格推荐使用

|---|
| |

的形式,另外像

标签都会在word生成目录,适配度还是挺好的。

3:生成的表格在word里可能会被截断,就是表格太长跑到了下一行,这个可以设置在word里面设置不让表格换页即可。要善于利用表格属性colspan,border-collapse: collapse等。

4:样式一定要写内联样式,bug最少!例如标准,内联样式里最好使用百分比,都是生效的,包括px都是可生效的

5:如果是在vue里面,像我就是额外搞一个"预览",其实就是把dom写在一个变量里,然后dom上用v-html即可实现预览,和word导出的效果差不多,例如

踩坑点:

1:如果要用img属性,注意:在内联样式里面,一定不要加单位,你放在页面上是会生效的,但是导出word就不行了。例子: 一定要加上引号,不要加单位(真是尝试了各种法子)

效果图:

导出PDF的js方法

只需要一个插件:html2pdf.js

安装:npm install --save html2pdf.js

js引入

import html2pdf from "html2pdf.js";

js方法

/**导出pdf方法 */

exportPdf(){

const element = document.getElementById("myContainer"); //这里不用像word需要innerHTML

const opt = {

margin: 1, //设置边距

filename: "文件.pdf", //导出文件名,要以.pdf为后缀,名字可随便改

image: { type: "JPED", quality: 0.98 },

//这点要着重讲一下,pdf其实本质上里面的是图片,这个插件其实使用了canves绘画的,这个选项也是决定了图片的格式和质量。质量越好文件越大

html2canvas: { scale: 2 }, //尽量加上的参数,缩放比,多次调试下,scale:2是最清楚的。

jsPDF: { //参数可固定

unit: "in",

format: "letter",

orientation: "portrait",

},

};

html2pdf().set(opt).from(element).save(); //导出pdf

}

踩坑点:

1:也是图片出现了问题:会发现图片导入不进去pdf,主要原因是我的img标签用的src是网络图片地址以http打头的,会导致图片显示不出来,要在dom元素内转成base64的格式,举个例子:,前端不建议写把图片转成base64的格式,亲测,如果图片大一点转base64就卡的批爆。建议是调用api或者后端接口传base64格式,再不行用网上的在线base64转换工具也可以,可以把base64图片地址放入变量用双向数据绑定。

2:导出的时候不管是文字、表格还是图片,会出现截断的情况,就是在两页中间,可能会出现断图,断字段表格的情况,这种情况研究了半个晚上。暂时找不到很好的解决方法,因为其实pdf本质上还是图片切割的。可能会有好的解决方法,暂时还不知道。

效果图:

说明:旨在用简单的代码实现效果,其实可配置内容还有很多。在这里把快速实现思路和一些踩坑点做一个总结。

最后附上插件的地址。有兴趣深入研究的可以看看。

File-save:https://github.com/eligrey/FileSaver.js

html-docx-js:https://github.com/evidenceprime/html-docx-js

html2pdf:https://github.com/eKoopmans/html2pdf.js

相关推荐
黄智勇3 分钟前
xlsx-handlebars 一个用于处理 XLSX 文件 Handlebars 模板的 Rust 库,支持多平台使
前端
brzhang1 小时前
为什么 OpenAI 不让 LLM 生成 UI?深度解析 OpenAI Apps SDK 背后的新一代交互范式
前端·后端·架构
brzhang2 小时前
OpenAI Apps SDK ,一个好的 App,不是让用户知道它该怎么用,而是让用户自然地知道自己在做什么。
前端·后端·架构
水冗水孚2 小时前
React中使用map+area标签实现img图片特定区域标记功能(可用Photoshop精准拾取对应点位)
react.js·html·photoshop
井柏然2 小时前
前端工程化—实战npm包深入理解 external 及实例唯一性
前端·javascript·前端工程化
IT_陈寒3 小时前
Redis 高性能缓存设计:7个核心优化策略让你的QPS提升300%
前端·人工智能·后端
井柏然3 小时前
从 npm 包实战深入理解 external 及实例唯一性
前端·javascript·前端工程化
玩泥巴的4 小时前
.NET驾驭Word之力:数据驱动文档 - 邮件合并与自定义数据填充完全指南
c#·word·.net·com互操作
羊锦磊4 小时前
[ vue 前端框架 ] 基本用法和vue.cli脚手架搭建
前端·vue.js·前端框架
brzhang4 小时前
高通把Arduino买了,你的“小破板”要变“AI核弹”了?
前端·后端·架构