vue實現pdf下載——html2canvas

html2canvas?官方文檔icon-default.png?t=N7T8https://html2canvas.hertzen.com/getting-started

html2canvas?的原理是通過遍歷DOM樹,將每一個HTML元素轉化為Canvas對象,并疊加到一起形成一張完整的圖片或者PDF文件

1. 安裝插件

npm install html2canvas jspdf --save

?2.使用(頁面已經寫好)

2.1 在頁面引入html2canvas

  1. import html2Canvas from 'html2canvas'

  2. import JsPDF from 'jspdf'

2.2 創建下載pdf頁面的方法

methods:{downloadPdf () {var title = "證書"html2Canvas(document.querySelector('#pdfDom'), {allowTaint: true}).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.3 頁面調用下載方法

?最終實現效果

? ? 原要下載的頁面

2. 下載的pdf

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/22959.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/22959.shtml
英文地址,請注明出處:http://en.pswp.cn/web/22959.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Stable Diffusion:多領域應用的創新引擎

一、引言 在當今數字化時代&#xff0c;人工智能技術的飛速發展為各個領域帶來了前所未有的機遇和挑戰。Stable Diffusion 作為一種先進的隨機過程模型&#xff0c;以其獨特的優勢和廣泛的應用潛力&#xff0c;成為了人工智能領域的研究熱點。本文將深入探討 Stable Diffusion…

git 的基本操作 Master and branch的版本合并 @ VS 1019

前言&#xff1a; 在VS 2019有git 的可視化管理,但&#xff0c;感覺微軟其實就是在git上包了一層。版本沖突后&#xff0c;還是要靠git 的命令行代碼搞。本文記錄了一次&#xff0c;branch和master的版本合并的過程。作為&#xff0c;后續的參考。 【注意&#xff0c;這個是一…

【二進制部署k8s-1.29.4】十三、metrics-server的安裝部署

文章目錄 簡介 一.metrics-server的安裝 簡介 本章節主要講解metrics-server的安裝&#xff0c;metrics-server主要是用于采集k8s中節點和pod的內存和cpu指標&#xff0c;在觀察幾點和pod的實時資源使用情況還是比較有用的&#xff0c;如果需要記錄歷史信息&#xff0c;建議采用…

運行編譯openjdk12-33

編譯環境 ubuntu20 Ubuntu里用戶可以自行選擇安裝GCC或CLang來進行編譯&#xff0c;但必須確保最低的版本為GCC 4.8或者CLang 3.2以上&#xff0c;官方推薦使用GCC 7.8或者CLang 9.1來完成編譯。 源碼 https://github.com/openjdk/jdk/tree/jdk-12%2B33 安裝gcc sudo apt…

人工智能的未來發展前景:機遇與挑戰

人工智能&#xff08;AI&#xff09;的發展在過去的幾十年里取得了突飛猛進的成就&#xff0c;已經成為推動全球科技創新的關鍵動力之一。隨著技術的不斷進步和應用的日益廣泛&#xff0c;AI的未來發展前景顯得更加廣闊&#xff0c;同時也面臨一系列新的機遇和挑戰。 技術革新…

使用neural_network_console訓練模型并導出.nnb文件應用于索尼spresense

一.創建數據集 首先你需要一個csv標記的數據集 然后我們使用neural_network_console將數據集進行處理 dataset->create dataset->image 用戶可以通過該界面選擇源目錄&#xff08;Source Dir&#xff09;&#xff0c;輸出目錄&#xff08;Output Dir&#xff09;&…

哈希表、HashMap\Map-1657. 確定兩個字符串是否接近

題目鏈接及描述 1657. 確定兩個字符串是否接近 - 力扣&#xff08;LeetCode&#xff09; 題目分析 今日看到這道題目&#xff0c;乍一看覺得非常熟悉&#xff0c;對于將一個字符串轉換為另一個字符串的題目之前做過一些。分析題目&#xff0c;題目中所述就是兩種操作&#xff…

ubuntu藍牙連接問題

ubuntu藍牙連接問題 ubuntu藍牙連接問題1、安裝驅動2、優化藍牙配置文件3、解決 Failed to connect: org.bluez.Error.Failed ubuntu藍牙連接問題 之前我發現電腦有藍牙圖標&#xff0c;且能打開關閉&#xff0c;就以為藍牙默認已經配置好了&#xff0c;直到有一天我嘗試連接我…

嵌入式軟件跳槽求指導?

嵌入式軟件行業的跳槽確實需要一些特定的策略和技巧。我這里有一套嵌入式入門教程&#xff0c;不僅包含了詳細的視頻講解&#xff0c;項目實戰。如果你渴望學習嵌入式&#xff0c;不妨點個關注&#xff0c;給個評論222&#xff0c;私信22&#xff0c;我在后臺發給你。 因為這個…

【設計模式】裝飾器模式(結構型)??

文章目錄 1.概念1.1 什么是裝飾器模式1.2 優點與缺點 2.實現方式3. Java 哪些地方用到了裝飾器模式4. Spring 哪些地方用到了裝飾器模式 1.概念 1.1 什么是裝飾器模式 它允許用戶在不修改現有對象的代碼的情況下向對象添加新的功能&#xff1b;這種模式是通過創建一個包含該對…

前端面試題日常練-day53 【面試題】

題目 希望這些選擇題能夠幫助您進行前端面試的準備&#xff0c;答案在文末 1. 在PHP中&#xff0c;以下哪個函數可以用于從一個數組的末尾刪除一個元素并返回被刪除的元素&#xff1f; a) array_pop() b) array_push() c) array_shift() d) array_unshift() 2. 在PHP中&…

列存在 OceanBase 數據庫架構中的應用與演進

OceanBase 4.3 版本上線了列存功能&#xff0c;以滿足實時分析的需求。 本文作為《特性解讀&#xff1a;列存技術》的后續&#xff0c;將詳細闡述列存技術在OceanBase數據庫架構中的應用、發展歷程&#xff0c;以及未來的趨勢。 一、前言 1970 年&#xff0c;關系模型之父 Co…

LeakSearch:針對網絡公開憑證的安全掃描與檢測工具

關于LeakSearch 在紅隊演戲過程中&#xff0c;往往需要獲取到針對目標域的訪問權限。在這個過程中&#xff0c;很多紅隊人員會選擇使用暴露在互聯網上的代理服務器來實現目標域的訪問&#xff0c;那么此時就需要在互聯網上收集公開暴露的憑證信息。 對于藍隊來說&#xff0c;…

Playwright+Python+Pytest:基礎方法二次封裝簡化及鏈式調用

引言 隨著Web應用的日益復雜化&#xff0c;自動化測試成為了確保軟件質量的關鍵環節。Playwright 是一個強大的自動化庫&#xff0c;它支持在 Chromium、Firefox 和 WebKit 中運行自動化腳本。本文將介紹如何使用 Playwright 的 Python 同步 API 來簡化點擊和填充操作&#xf…

阿里云郵件推送配置教程:API配置的步驟?

阿里云郵件推送服務如何使用&#xff1f;如何配置郵件推送服務&#xff1f; 阿里云提供了強大的郵件推送服務&#xff0c;幫助企業高效地發送郵件通知、驗證碼、營銷活動等。Aok將詳細介紹阿里云郵件推送的配置教程&#xff0c;以及API配置的步驟&#xff0c;同時簡要提及AokS…

數據流圖要點和難點實際應用

數據流圖(Data Flow Diagram,DFD)是一種圖形化表示信息系統中數據流動和處理的方式。它主要用于描述系統如何接收輸入數據,經過一系列的處理步驟,然后產生輸出數據。數據流圖在系統設計階段特別有用,因為它可以幫助開發人員、業務分析師和其他利益相關者更好地理解系統的…

Python字符串數據類型之字符串

四、Python數據類型 4.1、Python內置數據類型 整型&#xff1a;int浮點型&#xff1a;float布爾類型&#xff1a;bool字符串&#xff1a;str二進制類型&#xff1a;bytes、bytearray復數&#xff1a;complex列表&#xff1a;list元組&#xff1a;tuple字典&#xff1a;dict a…

C#WPF控件Textbox綁定浮點型數據限制小數位方法

本文講解C#WPF控件Textbox綁定浮點型數據限制小數位方法。 XAML中,使用StringFormat來格式化TextBox的文本 <Window x:Class="WpfApp.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.m…

【使用 uiautomator2 腳本進行波點音樂app自動化操作的教程】

本教程將指導您使用 uiautomator2 庫編寫腳本&#xff0c;實現自動化操作。如果您需要在設備斷開連接或出現異常時重新連接設備并繼續執行任務&#xff0c;這里有一份詳細的代碼示例和使用說明。 環境準備 安裝 Python&#xff1a; 確保您的系統上安裝了 Python&#xff08;推…

[數據集][目標檢測]盲道檢測數據集VOC+YOLO格式2173張1類別

數據集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路徑的txt文件&#xff0c;僅僅包含jpg圖片以及對應的VOC格式xml文件和yolo格式txt文件) 圖片數量(jpg文件個數)&#xff1a;2173 標注數量(xml文件個數)&#xff1a;2173 標注數量(txt文件個數)&#xff1a;2173 標注…