【Vue】vue2导出页面内容为pdf文件,自定义选中页面内容导出为pdf文件,打印选中页面内容,预览打印内容
创始人
2024-05-31 21:49:51
0

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • 一、安装html2canvas和jspdf
  • 二、导出pdf使用步骤
    • 1.在utils文件夹下创建htmlToPdf.js
    • 2.在main.js中引入
    • 3.在页面中使用
  • 三、打印预览
    • 1. 引入print-js
    • 2.页面中import
    • 3. 点击方法
  • 总结
  • 弹出打印框的另一种方式


前言

提示:这里可以添加本文要记录的大概内容:

打印页面中显示的部分内容,由div包括的所有内容都将被导出为pdf文件


提示:以下是本篇文章正文内容,下面案例可供参考

一、安装html2canvas和jspdf

npm install --save html2canvas;
npm install --save jspdf

二、导出pdf使用步骤

1.在utils文件夹下创建htmlToPdf.js

在这里插入图片描述

代码如下(示例):

// htmlToPdf.js
// 导出页面为PDF格式
/* 用法
1. main.js中引入
import htmlToPdf from '@/util/htmlToPdf'
Vue.use(htmlToPdf)2. vue页面中调用
按钮中方法  @click="getPdf()"
data中声明变量 
data() {return {htmlTitle: "测试导出文件", // 生成pdf的名称 ......
3. 打印内容 id必须为pdfDom
*/ import html2Canvas from 'html2canvas' import JsPDF from 'jspdf' export default {install(Vue, options) {Vue.prototype.getPdf = function() {var title = this.htmlTitle //html2Canvas(document.querySelector('#pdfDom'), {allowTaint: true,taintTest: false,useCORS: true,// y: 72, // 对Y轴进行裁切// width:1200,// height:5000,dpi: window.devicePixelRatio * 4, //将分辨率提高到特定的DPI 提高四倍scale: 4 //按比例增加分辨率 }).then(function(canvas) {let contentWidth = canvas.widthlet contentHeight = canvas.heightlet pageHeight = contentWidth / 592.28 * 841.89let leftHeight = contentHeightlet position = 0let imgWidth = 595.28let imgHeight = 592.28 / contentWidth * contentHeightlet pageData = canvas.toDataURL('image/jpeg', 1.0)let PDF = new JsPDF('', 'pt', 'a4')if (leftHeight < pageHeight) {PDF.addImage(pageData, 'JPEG', 0, 0, imgWidth, imgHeight)} else {while (leftHeight > 0) {PDF.addImage(pageData, 'JPEG', 0, position, imgWidth, imgHeight)leftHeight -= pageHeightposition -= 841.89if (leftHeight > 0) {PDF.addPage()}}}PDF.save(title + '.pdf')})}} }

2.在main.js中引入

代码如下(示例):

import htmlToPdf from './utils/htmlToPdf.js'
Vue.use(htmlToPdf)

在这里插入图片描述

3.在页面中使用

页面内容代码


2023年3月10日11:40:12

测试结束

导出文件查看打印效果

css样式

.tableBox {margin: 0 auto;width: 750px;display: flex;justify-content: center;align-items: center;flex-direction: column;padding: 20px;border: 1px solid #3399cc;h1 {text-align: center;}.el-table {margin: 20px 0;}
}
.onBtn{margin: 30px auto;display: flex;align-items: center;justify-content: center;
}

js变量

htmlTitle: "测试导出文件", // 生成pdf的名称 
tableData: [{date: '2016-05-02',name: '王小虎',address: '上海市普陀区金沙江路 1518 弄'
}, {date: '2016-05-04',name: '王小虎',address: '上海市普陀区金沙江路 1517 弄'
}, {date: '2016-05-01',name: '王小虎',address: '上海市普陀区金沙江路 1519 弄'
}, {date: '2016-05-03',name: '王小虎',address: '上海市普陀区金沙江路 1516 弄'
}]

在这里插入图片描述

  • getPdf方法为htmlToPdf.js中创建的,并且已经在main.js中引用为全局

  • data变量里面必须自定义一个title名称,要与js中相对应。
    在这里插入图片描述
    在这里插入图片描述

  • 导出内容div里面必须定义id,必须一致
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

三、打印预览

1. 引入print-js

npm install --save print-js

2.页面中import

import printJS from 'print-js'
import html2Canvas from 'html2canvas'

在这里插入图片描述

3. 点击方法

首先要在打印内容中加一个ref绑定
在这里插入图片描述
在这里插入图片描述

goPrint() {this.isPrint = truehtml2Canvas(this.$refs.print, {allowTaint: true,taintTest: false,useCORS: true,dpi: window.devicePixelRatio * 4,scale: 4}).then((canvas) => {const url = canvas.toDataURL()printJS({printable: url, // 要打印的idtype: 'image',style: '@page{size:auto;margin: 0cm 1cm 0cm 1cm;}' //去除页眉页脚})this.isPrint = false})
}

总结

完整页面代码


弹出打印框的另一种方式

下载安装

npm install --save vue-print-nb

main.js引入

// vue打印插件 vue-print-nb
import Print from 'vue-print-nb'
Vue.use(Print)

用法
在这里插入图片描述
效果就是弹出浏览器自带的打印,与导出pdf文件是两码事
在这里插入图片描述

相关内容

热门资讯

平板安卓系统找不到了,探寻系统... 亲爱的读者,你是否也有过这样的经历:手机里突然找不到那个熟悉的安卓平板系统图标了?别急,让我带你一探...
检查充电系统和安卓拍照,充电系... 亲爱的读者们,今天我要和你聊聊两个超级实用的话题:检查充电系统和安卓拍照。这两个小细节,可是让你的手...
原生安卓如何刷小米系统,小米系... 亲爱的安卓爱好者们,你是否曾对原生安卓的纯净体验心驰神往,同时又对小米系统的丰富功能爱不释手?别急,...
安卓系统有多少等级的,揭秘其多... 你有没有想过,那个陪伴我们日常生活的安卓系统,它其实有着丰富的等级体系呢?没错,就是那个让我们的手机...
安卓系统重装win10系统,轻... 你有没有想过,你的安卓手机突然间变得卡顿不堪,仿佛被时间遗忘的机器?别急,今天就来教你一招,如何让你...
双机系统需要寻址吗安卓,双机系... 你有没有想过,你的安卓手机里那双机系统,是不是也需要有个家呢?没错,就是寻址!别小看了这个小小的动作...
安卓系统最好的日程软件 你有没有发现,每天的生活就像一场马拉松,时间就像那不停歇的跑步机,你得紧紧抓住它,才能不被甩在后面。...
安卓系统对音质的影响,安卓系统... 你有没有发现,用安卓手机听音乐的时候,音质好像总是不那么完美呢?是不是觉得有时候声音有点闷,或者高频...
王者系统转移安卓转苹果,畅享跨... 你有没有想过,把你在安卓手机上玩得风生水起的《王者荣耀》账号,转移到苹果手机上继续征战呢?这可不是一...
清理车机安卓系统垃圾,释放性能... 亲爱的车主朋友们,你是不是也和我一样,发现车机里的安卓系统越来越慢,就像老牛拉破车一样,让人头疼不已...
华为哪个手机是安卓系统,探索华... 你有没有想过,华为那么多手机,哪一款才是真正搭载了安卓系统的呢?别急,今天我就来给你好好捋一捋,让你...
揽胜可以安装安卓系统吗,安卓系... 你有没有想过,你的揽胜SUV不仅能驰骋在山川湖海之间,还能变身成为一个移动的智能中心呢?没错,今天就...
王牌战士安卓系统下载,畅享竞技... 亲爱的玩家们,你是否在寻找一款刺激的射击游戏来释放你的战斗热情?如果你的答案是肯定的,那么今天我要给...
小米安卓7.0系统特点,创新体... 你知道吗?最近小米手机的新系统安卓7.0可是火得一塌糊涂呢!作为一个紧跟科技潮流的数码爱好者,我当然...
安卓老系统怎么下载软件,轻松找... 你那安卓老系统是不是有点儿落伍了?别急,今天就来给你支个招,教你怎么下载那些新鲜出炉的软件,让你的手...
安卓系统升级鸿蒙系统后app,... 你知道吗?最近手机界可是掀起了一股不小的风潮呢!那就是安卓系统升级到鸿蒙系统后,那些我们熟悉的app...
阿里os系统能装安卓 你知道吗?最近在科技圈里可是掀起了一股热潮,那就是阿里OS系统能装安卓的消息。这可不是什么小道消息,...
香橙派one安卓系统,轻巧便携... 你有没有听说过香橙派One这款小玩意儿?它可是最近在科技圈里火得一塌糊涂呢!想象一个迷你电脑,却能装...
怎么恢复到安卓系统,重拾流畅体... 手机用久了,是不是突然觉得卡得要命,想给它来个“大变身”?别急,今天就来教你怎么把安卓手机恢复到原厂...
魅族系统基于安卓5.0,基于安... 亲爱的数码爱好者们,今天我要和你聊聊一个特别的话题——魅族系统。你可能已经知道,魅族手机以其独特的F...