Vue中將頁面導出為PDF(vue2)

實現(xiàn)思路:在Vue中實際是把頁面利用canvas轉換成圖片介返,然后再用圖片的base64碼轉成PDF咱揍,這里就使用到了兩個插件html2canvas和jspdf

image.png

第一步
安裝兩個插件:

npm install --save html2canvas //html頁面轉換成圖片
npm install jspdf --save //把base64轉換為PDF

第二步
在目錄src下創(chuàng)建utils文件夾,里面創(chuàng)建一個exportPdf.js,將下面內容復制到js文件里面

// 導出頁面為PDF格式
import html2Canvas from 'html2canvas'
import JsPDF from 'jspdf'

export function getPdf(title,id){
  html2Canvas(document.querySelector(`#${id}`), {
    allowTaint: true
  }).then(function (canvas) {
    let contentWidth = canvas.width
    let contentHeight = canvas.height
    let pageHeight = contentWidth / 592.28 * 841.89
    let leftHeight = contentHeight
    let position = 0
    let imgWidth = 595.28
    let imgHeight = 592.28 / contentWidth * contentHeight
    let 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 -= pageHeight
        position -= 841.89
        if (leftHeight > 0) {
          PDF.addPage()
        }
      }
    }
    PDF.save(title + '.pdf')
  }
  )
}

第三步
在項目或者需要用到的組件中引入方法


image.png

第四步
使用方法
HTML

<!-- 這里就是要變成圖片的容器 -->
<div id="pdfHtml" ref="printHtml" style="text-align: center">
    <img src='../assets/logo.png'/>
</div> 
<button type="primary" @click="exportPDF">導出PDF</button>

JS

// 導出PDF
exportPDF() {
   getPdf('測試','pdfHtml');
},

全部代碼

<template>
    <div>
        <!-- 這里就是要變成圖片的容器 -->
        <div id="pdfHtml" ref="printHtml" style="text-align: center">
            <img src="../assets/logo.png" />
        </div>
        <button type="primary" @click="exportPDF">導出PDF</button>
    </div>
</template>

<script>
import { getPdf } from '../utils/exportPdf';
export default {
    methods: {
        // 導出PDF
        exportPDF() {
            getPdf('測試', 'pdfHtml');
        },
    },
};
</script>

<style>
</style>

展示


image.png

image.png
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末嘹屯,一起剝皮案震驚了整個濱河市埃仪,隨后出現(xiàn)的幾起案子沙绝,更是在濱河造成了極大的恐慌捌归,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,188評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件告喊,死亡現(xiàn)場離奇詭異麸拄,居然都是意外死亡派昧,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評論 3 395
  • 文/潘曉璐 我一進店門感帅,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人地淀,你說我怎么就攤上這事失球。” “怎么了帮毁?”我有些...
    開封第一講書人閱讀 165,562評論 0 356
  • 文/不壞的土叔 我叫張陵实苞,是天一觀的道長。 經(jīng)常有香客問我烈疚,道長黔牵,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,893評論 1 295
  • 正文 為了忘掉前任爷肝,我火速辦了婚禮猾浦,結果婚禮上,老公的妹妹穿的比我還像新娘灯抛。我一直安慰自己金赦,他們只是感情好,可當我...
    茶點故事閱讀 67,917評論 6 392
  • 文/花漫 我一把揭開白布对嚼。 她就那樣靜靜地躺著夹抗,像睡著了一般。 火紅的嫁衣襯著肌膚如雪纵竖。 梳的紋絲不亂的頭發(fā)上漠烧,一...
    開封第一講書人閱讀 51,708評論 1 305
  • 那天,我揣著相機與錄音靡砌,去河邊找鬼已脓。 笑死,一個胖子當著我的面吹牛通殃,可吹牛的內容都是我干的摆舟。 我是一名探鬼主播,決...
    沈念sama閱讀 40,430評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼邓了,長吁一口氣:“原來是場噩夢啊……” “哼恨诱!你這毒婦竟也來了?” 一聲冷哼從身側響起骗炉,我...
    開封第一講書人閱讀 39,342評論 0 276
  • 序言:老撾萬榮一對情侶失蹤照宝,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后句葵,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體厕鹃,經(jīng)...
    沈念sama閱讀 45,801評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡兢仰,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,976評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了剂碴。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片把将。...
    茶點故事閱讀 40,115評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖忆矛,靈堂內的尸體忽然破棺而出察蹲,到底是詐尸還是另有隱情,我是刑警寧澤催训,帶...
    沈念sama閱讀 35,804評論 5 346
  • 正文 年R本政府宣布洽议,位于F島的核電站,受9級特大地震影響漫拭,放射性物質發(fā)生泄漏亚兄。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,458評論 3 331
  • 文/蒙蒙 一采驻、第九天 我趴在偏房一處隱蔽的房頂上張望审胚。 院中可真熱鬧,春花似錦礼旅、人聲如沸菲盾。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽懒鉴。三九已至,卻和暖如春碎浇,著一層夾襖步出監(jiān)牢的瞬間临谱,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評論 1 272
  • 我被黑心中介騙來泰國打工奴璃, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留悉默,地道東北人。 一個月前我還...
    沈念sama閱讀 48,365評論 3 373
  • 正文 我出身青樓苟穆,卻偏偏與公主長得像抄课,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子雳旅,可洞房花燭夜當晚...
    茶點故事閱讀 45,055評論 2 355

推薦閱讀更多精彩內容