前端:纯前端快速实现html导出word和pdf
创始人
2024-12-29 05:33:43
0

实现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

相关内容

热门资讯

来临!山西扣点点脚本辅助器,关... 来临!山西扣点点脚本辅助器,关春天开挂(本来有挂插件)-哔哩哔哩1、点击下载安装,山西扣点点脚本辅助...
突发!微乐降序自建房辅助app... 突发!微乐降序自建房辅助app,福建天天开心辅助器真的假的(好像是真的app)-哔哩哔哩1)福建天天...
来临!丫丫陕西扑克绿色透视,微... 来临!丫丫陕西扑克绿色透视,微乐小程序辅助脚本平台(真是是真的工具)-哔哩哔哩1、微乐小程序辅助脚本...
反观!微乐陕西三代自建房挂,新... 反观!微乐陕西三代自建房挂,新九游辅助软件(原来真的有插件)-哔哩哔哩亲,关键说明,微乐陕西三代自建...
刚刚!皇豪互众辅助软件是干嘛的... 您好,皇豪互众辅助软件是干嘛的这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302...
据权威媒体报道!凑一桌游戏插件... 据权威媒体报道!凑一桌游戏插件,陕西三代辅助器免费(本来真的有挂)-哔哩哔哩1、陕西三代辅助器免费公...
近年来!微信超级三加一辅助,广... 近年来!微信超级三加一辅助,广西老友玩游戏辅助器(本来真的是有脚本)-哔哩哔哩1、每一步都需要思考,...
连日来!中至赣牌圈黑科技挂件有... 连日来!中至赣牌圈黑科技挂件有真的吗,凑一桌游戏插件(好像真的是有修改器)-哔哩哔哩1、实时中至赣牌...
突发!赣湘互娱辅助,山西奇迹打... 突发!赣湘互娱辅助,山西奇迹打锅子辅助(都是真的是有app)-哔哩哔哩进入游戏-大厅左侧-新手福利-...
经核实!微乐山西威信小程序,奇... 经核实!微乐山西威信小程序,奇迹陕西靖边打锅子辅助(真是是真的软件)-哔哩哔哩所有人都在同一条线上,...