实现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,也就是像<div id="myContainer"></div>
let content = `
<!DOCTYPE html><html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
</head>
<body>
<div>
${contentHtml}
</div>
</body>
</html>`;
console.log(content)
let converted = htmlDocx.asBlob(content);//利用插件转
FileSaver.saveAs(converted, "xxx.docx");//导出为word,要以.docx为后缀,xxxx可任意名字
},
要注意的点及推荐:
1:要导出word的html代码不推荐使用组件,例如<el-table>等,bug很多,最好使用原始的html代码。但是像v-model这种数据绑定的都是可以用的
2:表格推荐使用<table> <tr> <td> </td> </tr> </table>的形式,另外像<h1>标签都会在word生成目录,适配度还是挺好的。
3:生成的表格在word里可能会被截断,就是表格太长跑到了下一行,这个可以设置在word里面设置不让表格换页即可。要善于利用表格属性 colspan,border-collapse: collapse等。
4:样式一定要写内联样式,bug最少!例如 <td style="width:33%; height: 50px; text-align: center;">标准</td>,内联样式里最好使用百分比,都是生效的,包括px都是可生效的
5:如果是在vue里面,像我就是额外搞一个"预览",其实就是把dom写在一个变量里,然后dom上用v-html即可实现预览,和word导出的效果差不多,例如<div id="myContainer" v-html="generatePreviewContent()"></div>
踩坑点:
1:如果要用img属性,注意:在内联样式里面,一定不要加单位,你放在页面上是会生效的,但是导出word就不行了。例子:<img width="200" height="160" src="${image.address}" > 一定要加上引号,不要加单位(真是尝试了各种法子)
效果图:
导出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的格式,举个例子:<img width="200" height="160" src="">,前端不建议写把图片转成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