页面html结构导出为word或pdf

一、使用场景和原理

需要将当前页面(一般详情页面)或者dom容器中的内容保存/截图,并且导出为word或者pdf

导出word:获取dom结构直接转化为word导出

导出pdf:用canvas生成当前页面或者dom范围的快照,参考截图功能,然后将生成的canvas转为pdf内容并导出

二、需要用到的插件
复制代码
npm i mhtml-to-word --save  //html结构转为word插件
npm i html2canvas --save  //获取dom,用canvas画下来,转为base64格式
npm i jspdf --save	//将canvas内容转为pdf内容
三、使用
复制代码
import { exportWord } from 'mhtml-to-word'
import html2canvas from 'html2canvas';
import jsPDF from 'jspdf';

导出为word:

复制代码
exportToWord=(e)=>{
    e.preventDefault();
    exportWord({
      filename: "日报详情",
      selector: ".dailyDetail",    //容器id
      style:''
    })
}

导出为pdf:

复制代码
exportToPdf=(e)=>{
    e.preventDefault();
    let dom = document.getElementById('dailyDetail');
    let w = dom.offsetWidth
    let h = dom.offsetHeight
    html2canvas(dom)
      .then((canvas) => {
      	//第一个参数为第一页pdf方向,p为纵向i为横向;第二个为单位,一般取mm,px;
      	//第三个为第一页的格式
        let pdf = new jsPDF('p', 'px', 'a4');   
        //参数1:图片资源,可以是图片文件的路径或者base64编码字符串
        //参数2:类型
        //参数3,4:图片在PDF中的x、y轴坐标
        //参数5,6:图片在PDF中的宽度、高度
        //参数7(可选):指定图片资源的别名
        //参数8(可选):指定图片的压缩质量,取值为0-1之间的浮点数
        //参数9(可选):指定图片的旋转角度,取值范围为0-360之间的整数
        pdf.addImage(canvas.toDataURL('image/png'), 'PNG', 0, 0, w, h);
        pdf.save('日报详情.pdf');
    });
}
相关推荐
xiaoqi92224 分钟前
React Native鸿蒙跨平台如何进行狗狗领养中心,实现基于唯一标识的事件透传方式是移动端列表开发的通用规范
javascript·react native·react.js·ecmascript·harmonyos
jin1233221 小时前
React Native鸿蒙跨平台剧本杀组队消息与快捷入口组件,包含消息列表展示、快捷入口管理、快捷操作触发和消息详情预览四大核心功能
javascript·react native·react.js·ecmascript·harmonyos
烬头88212 小时前
React Native鸿蒙跨平台实现二维码联系人APP(QRCodeContactApp)
javascript·react native·react.js·ecmascript·harmonyos
pas1362 小时前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
摇滚侠3 小时前
2 小时快速入门 ES6 基础视频教程
前端·ecmascript·es6
2601_949833393 小时前
flutter_for_openharmony口腔护理app实战+预约管理实现
android·javascript·flutter
珑墨3 小时前
【Turbo】使用介绍
前端
军军君014 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
xiaoqi9225 小时前
React Native鸿蒙跨平台如何实现分类页面组件通过searchQuery状态变量管理搜索输入,实现了分类的实时过滤功能
javascript·react native·react.js·ecmascript·harmonyos
打小就很皮...5 小时前
Tesseract.js OCR 中文识别
前端·react.js·ocr