欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue網頁html轉換PDF(最低兼容ie10)的思路詳解

 更新時間:2017年08月24日 08:19:07   作者:冷藏封  
這篇文章主要介紹了Vue網頁html轉換PDF(最低兼容ie10)的思路詳解,實現此功能需要引入兩個插件,需要的朋友可以參考下

HTML轉PDF:

1.頁面底層實現——Vue:最低兼容ie10  

2.實現思路:

  1> 使用html2canvas.js將網頁轉換為圖片

  2> 使用jsPdf.debug.js將canvas生成的圖片轉換為pdf文件

具體實現:

  要這樣實現首先要引入兩個插件:

    html2canvas.js

    jsPdf.debug.js

注:

  因為ie10在canvas截圖時候會出現部分樣式丟失的情況,所以在代碼中有部分修改了頁面的樣式

  所以建議在做截圖的時候,將頁面代碼復制一份到隱藏域,在隱藏域里面做修改,這樣就不會修改頁面原有樣式了

  如果大家有更好的方法,歡迎提議

下面上代碼:

<script type="text/ecmascript-6">
import co from 'co'
import html2Canvas from '../html2canvas'
import JsPDF from '../jsPdf.debug'
export default {
 title: '用戶信息',
 data () {
  return {}
 },
 methods: {
   // 核心代碼
  printOut () {
    // 獲取需要打印的區(qū)域,以div為單位,此處使用的是vue的選擇器
   let pdfDom = document.querySelector('#pdf-wrap')
    // 因為在ie10下,會出現input樣式丟失的情況,所以在此處清楚input的標簽的邊框
   let arrnode = pdfDom.querySelectorAll('input')
   for (var i = 0; i < arrnode.length; i++) {
    arrnode[i].style.border = 'hidden'
   }
    // 設置背景色
   pdfDom.style.background = '#FFFFFF'
   let _this = this
   html2Canvas(pdfDom, {
    allowTaint: true, taintTest: false,
    onrendered: function (canvas) {
      // 開始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
      // 此處圖片格式可以是PNG,也可是JPEG,注意:需要考慮Browser支持的圖片格式
     let pageData = canvas.toDataURL('image/PNG', 1)
     pdfDom.style.display = 'none'
      // 開始將圖片轉換為PDF
      // 設置紙張大小,方向
     let PDF = new JsPDF('', 'pt', 'a4')
     if (leftHeight < pageHeight) {
      PDF.addImage(pageData, 'PNG', 0, 0, imgWidth, imgHeight)
     } else {
      while (leftHeight > 0) {
       PDF.addImage(pageData, 'PNG', 0, position, imgWidth, imgHeight)
       leftHeight -= pageHeight
       position -= 841.89
       if (leftHeight > 0) {
        PDF.addPage()
       }
      }
     }
      // 保存PDF
     PDF.save(_this.userInfo.card_id + '-' + _this.userInfo.user_name + '.pdf')
    }
   })
   html2Canvas()
  }
 },
 ready () {
 }
}
</script>

總結

以上所述是小編給大家介紹的Vue網頁html轉換PDF(最低兼容ie10)的思路詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

相關文章

  • Vue實現簡單的發(fā)表評論功能

    Vue實現簡單的發(fā)表評論功能

    這篇文章主要為大家詳細介紹了Vue實現簡單的發(fā)表評論功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • vue+echarts動態(tài)更新數據及數據變化重新渲染方式

    vue+echarts動態(tài)更新數據及數據變化重新渲染方式

    這篇文章主要介紹了vue+echarts動態(tài)更新數據及數據變化重新渲染方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • vue開發(fā)之不同瀏覽器的類型判斷方式

    vue開發(fā)之不同瀏覽器的類型判斷方式

    這篇文章主要介紹了vue開發(fā)之不同瀏覽器的類型判斷方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 淺談VUE監(jiān)聽窗口變化事件的問題

    淺談VUE監(jiān)聽窗口變化事件的問題

    下面小編就為大家分享一篇淺談VUE監(jiān)聽窗口變化事件的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • vue如何將html內容轉為圖片并下載到本地

    vue如何將html內容轉為圖片并下載到本地

    這篇文章主要介紹了vue如何將html內容轉為圖片并下載到本地,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • vue調用高德地圖實例代碼

    vue調用高德地圖實例代碼

    本篇文章主要介紹了vue調用高德地圖實例代碼,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • 關于Vue中axios的封裝實例詳解

    關于Vue中axios的封裝實例詳解

    這篇文章主要給大家介紹了關于Vue中axios的封裝的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者使用Vue具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-10-10
  • 在?Vue?中使用?iframe?嵌套頁面的步驟

    在?Vue?中使用?iframe?嵌套頁面的步驟

    這篇文章主要介紹了在?Vue?中使用?iframe?嵌套頁面,使用?iframe?技術可以實現多個頁面之間的數據傳遞和交互,提高了網站的整體性能和用戶體驗,需要的朋友可以參考下
    2023-05-05
  • effect返回runner單測實現示例詳解

    effect返回runner單測實現示例詳解

    這篇文章主要為大家介紹了effect返回runner單測實現示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • Vue組件間通信的實現方法講解

    Vue組件間通信的實現方法講解

    組件是vue.js最強大的功能之一,而組件實例的作用域是相互獨立的,這就意味著不同組件之間的數據無法相互進行直接的引用,所以組件間的相互通信是非常重要的
    2023-01-01

最新評論