日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > vue >内容正文

vue

Vue中使用html2canvas和jspdf插件实现导出pdf(自定义html样式可带图片)并下载

發布時間:2025/3/19 vue 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Vue中使用html2canvas和jspdf插件实现导出pdf(自定义html样式可带图片)并下载 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

場景

若依前后端分離版手把手教你本地搭建環境并運行項目:

若依前后端分離版手把手教你本地搭建環境并運行項目_BADAO_LIUMANG_QIZHI的博客-CSDN博客_若依前后端分離文檔

在上面搭建起來框架的基礎上,怎樣實現前端將html頁面的內容導出為pdf。

html2canvas官網

html2canvas - Screenshots with JavaScript

注:

博客:
BADAO_LIUMANG_QIZHI的博客_霸道流氓氣質_CSDN博客-C#,SpringBoot,架構之路領域博主
關注公眾號
霸道的程序猿
獲取編程相關電子書、教程推送與免費下載。

實現

1、安裝插件

// 將頁面 html 轉換成圖片 npm install html2canvas --save? // 將圖片生成 pdf npm install jspdf --save

2、頁面上添加要導出的html元素

? <div class="wrap" ><div id="pdfDom" style="padding: 10px;"><el-table:data="tableData"border><el-table-column prop="date" label="日期" width="250"></el-table-column><el-table-column prop="name" label="姓名" width="250"></el-table-column><el-table-column prop="address" label="地址"></el-table-column></el-table><el-image :src="logo"></el-image></div><button type="button" style="margin-top: 20px;" @click="btnClick">導出PDF</button></div>

其中id為pdfDom的div里面是要導出為pdf的內容

el-image是一張要顯示的圖片

3、導出按鈕的點擊事件

??? btnClick(){// 當下載pdf時,若不在頁面頂部會造成PDF樣式不對,所以先回到頁面頂部再下載let top = document.getElementById('pdfDom');if (top != null) {top.scrollIntoView();top = null;}let title = this.exportPDFtitle;html2Canvas(document.querySelector('#pdfDom'), {allowTaint: true}).then(function (canvas) {// 獲取canvas畫布的寬高let contentWidth = canvas.width;let contentHeight = canvas.height;// 一頁pdf顯示html頁面生成的canvas高度;let pageHeight = contentWidth / 841.89 * 592.28;// 未生成pdf的html頁面高度let leftHeight = contentHeight;// 頁面偏移let position = 0;// html頁面生成的canvas在pdf中圖片的寬高(本例為:橫向a4紙[841.89,592.28],縱向需調換尺寸)let imgWidth = 841.89;let imgHeight = 841.89 / contentWidth * contentHeight;let pageData = canvas.toDataURL('image/jpeg', 1.0);let PDF = new JsPDF('l', 'pt', 'a4');// 兩個高度需要區分: 一個是html頁面的實際高度,和生成pdf的頁面高度// 當內容未超過pdf一頁顯示的范圍,無需分頁if (leftHeight < pageHeight) {PDF.addImage(pageData, 'JPEG', 0, 0, imgWidth, imgHeight)} else {while (leftHeight > 0) {PDF.addImage(pageData, 'JPEG', 0, position, imgWidth, imgHeight)leftHeight -= pageHeight;position -= 592.28;// 避免添加空白頁if (leftHeight > 0) {PDF.addPage();}}}PDF.save(title + '.pdf')})},

4、完整示例代碼

<template><div class="wrap" ><div id="pdfDom" style="padding: 10px;"><el-table:data="tableData"border><el-table-column prop="date" label="日期" width="250"></el-table-column><el-table-column prop="name" label="姓名" width="250"></el-table-column><el-table-column prop="address" label="地址"></el-table-column></el-table><el-image :src="logo"></el-image></div><button type="button" style="margin-top: 20px;" @click="btnClick">導出PDF</button></div> </template><script> // 導出頁面為PDF格式 import html2Canvas from 'html2canvas' import JsPDF from 'jspdf' import logoImg from '@/assets/logo/logo.png' export default {name: "ExportPDF",data() {return {logo: logoImg,exportPDFtitle: "頁面導出PDF文件名",tableData: [{date: '2016-05-06',name: '王小虎',address: '重慶市九龍坡區火炬大道'}, {date: '2016-05-07',name: '王小虎',address: '重慶市九龍坡區火炬大道'},{date: '2016-05-03',name: '王小虎',address: '上海市普陀區金沙江路 1518 弄'}, {date: '2016-05-02',name: '王小虎',address: '上海市普陀區金沙江路 1518 弄'}, {date: '2016-05-04',name: '王小虎',address: '上海市普陀區金沙江路 1518 弄'}, {date: '2016-05-01',name: '王小虎',address: '上海市普陀區金沙江路 1518 弄'}, {date: '2016-05-08',name: '王小虎',address: '上海市普陀區金沙江路 1518 弄'}, {date: '2016-05-06',name: '王小虎',address: '上海市普陀區金沙江路 1518 弄'}, {date: '2016-05-06',name: '王小虎',address: '上海市普陀區金沙江路 1518 弄'},]};},mounted() {},methods: {btnClick(){// 當下載pdf時,若不在頁面頂部會造成PDF樣式不對,所以先回到頁面頂部再下載let top = document.getElementById('pdfDom');if (top != null) {top.scrollIntoView();top = null;}let title = this.exportPDFtitle;html2Canvas(document.querySelector('#pdfDom'), {allowTaint: true}).then(function (canvas) {// 獲取canvas畫布的寬高let contentWidth = canvas.width;let contentHeight = canvas.height;// 一頁pdf顯示html頁面生成的canvas高度;let pageHeight = contentWidth / 841.89 * 592.28;// 未生成pdf的html頁面高度let leftHeight = contentHeight;// 頁面偏移let position = 0;// html頁面生成的canvas在pdf中圖片的寬高(本例為:橫向a4紙[841.89,592.28],縱向需調換尺寸)let imgWidth = 841.89;let imgHeight = 841.89 / contentWidth * contentHeight;let pageData = canvas.toDataURL('image/jpeg', 1.0);let PDF = new JsPDF('l', 'pt', 'a4');// 兩個高度需要區分: 一個是html頁面的實際高度,和生成pdf的頁面高度// 當內容未超過pdf一頁顯示的范圍,無需分頁if (leftHeight < pageHeight) {PDF.addImage(pageData, 'JPEG', 0, 0, imgWidth, imgHeight)} else {while (leftHeight > 0) {PDF.addImage(pageData, 'JPEG', 0, position, imgWidth, imgHeight)leftHeight -= pageHeight;position -= 592.28;// 避免添加空白頁if (leftHeight > 0) {PDF.addPage();}}}PDF.save(title + '.pdf')})},}, }; </script><style scoped></style>

總結

以上是生活随笔為你收集整理的Vue中使用html2canvas和jspdf插件实现导出pdf(自定义html样式可带图片)并下载的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 免费av一区二区三区 | 亚洲成年 | 爱爱色图 | 午夜精品久久久内射近拍高清 | 曰本黄色大片 | 国产肥老妇视频 | 成人性生交大片免费看r链接 | 网站黄在线观看 | 黄色三级网站在线观看 | 一道本在线播放 | 亚洲18在线看污www麻豆 | 国产美女菊爆在线播放APP | 国产美女又黄又爽又色视频免费 | 99r热| 男人天堂99 | 色播欧美| 亚洲网站视频 | 夜福利视频 | 欧美激情小视频 | 一卡二卡在线 | 日韩中文字幕一区二区 | 樱桃香蕉视频 | 香蕉视频成人在线观看 | 中文字幕第4页 | 亚洲色精品三区二区一区 | 日韩3p | 99在线观看 | 亚洲情热 | 91成人在线观看喷潮动漫 | 精品人妻一区二区三区蜜桃 | 全黄一级男人和女人 | 日日骚av一区二区 | 日韩伦理在线视频 | 99热官网 | 中文字幕av一区二区三区人妻少妇 | av片亚洲 | 欧美一级淫片免费视频魅影视频 | 中文字幕久久网 | 成人国产网站 | 亚洲精品水蜜桃 | 欧美人体做爰大胆视频 | 日本黄页网站 | а√天堂资源官网在线资源 | 九色国产在线 | yy111122少妇光屁股影院 | 亚洲女优在线播放 | 青娱乐av在线 | 最新黄色网址在线观看 | 红桃视频成人 | 国产成人精品一区二区三区无码熬 | 日韩一级一区 | 日日夜夜爱爱 | 欧美射射射 | 久久综合久久综合久久综合 | 日本3p视频 | 视频在线观看一区二区三区 | 农民工hdxxxx性中国 | 亚洲三级网 | 亚洲欧美第一页 | 天狂传说之巴啦啦小魔仙 | 久久精品操 | 国产一级免费大片 | 午夜影院污 | 性感美女在线观看 | 国产乱人乱偷精品视频a人人澡 | 丁香激情五月少妇 | 热久久这里只有精品 | 粉嫩av国产一区二区三区 | 精品人妻伦一区二区三区久久 | 一级片大片| 国产男女自拍 | 波多野在线 | 国产原创在线观看 | 这里只有精品在线播放 | 三年中国片在线高清观看 | 91看片就是不一样 | 在线欧美日韩国产 | 一本到免费视频 | 性生交大全免费看 | 麻豆传媒网站 | 欧美网站在线观看 | a毛片毛片av永久免费 | 欧美成人久久久免费播放 | 视频一区二区在线播放 | 欧美一区二区三区四区在线 | 精品啪啪 | 激情小说在线观看 | 国内偷拍久久 | 色图在线观看 | 成人手机在线观看 | 国产色网址 | 欧美亚洲免费 | 国产三级在线观看视频 | 少妇精品久久久久久久久久 | 麻豆视频精品 | 清纯唯美亚洲激情 | 少妇太紧太爽又黄又硬又爽小说 | 亚洲高清免费观看 | 超碰视屏 |