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

vue如何使用html2canvas和JsPDF導(dǎo)出pdf組件

 更新時(shí)間:2024年09月13日 10:05:33   作者:侯六六  
這篇文章主要介紹了vue如何使用html2canvas和JsPDF導(dǎo)出pdf組件問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

使用html2canvas和JsPDF導(dǎo)出pdf組件

來看實(shí)例

<template>
  <div class="g-down-pdf">
    <div  ref="pdfDom">
    //插入的內(nèi)容
       <slot name="content" ></slot>
    </div>
    <div @click="savePdf" class="get-pdf">
      <slot name="button">     
      	<div>下載PDF</div>
      </slot>
    </div>
  </div>
</template>
<script>
import html2canvas from 'html2canvas'
import JsPDF from 'jspdf'
export default {
  components: {

  },
  props: {

  },
  data() {
    return {
    }
  },
  methods: {
    savePdf() {
      const title = '評(píng)估報(bào)告'
      // 滾動(dòng)條會(huì)導(dǎo)致空白 導(dǎo)出時(shí)需置頂
      window.pageYOffset = 0
      document.documentElement.scrollTop = 0
      document.body.scrollTop = 0 
	 
	  // 在ios手機(jī)上會(huì)導(dǎo)致 上方空白 后邊內(nèi)容丟失  在電腦瀏覽器上的ios并不會(huì)
	  const u = navigator.userAgent
      const isAndroid = u.indexOf('Android') > -1 || u.indexOf('Adr') > -1 // android終端
      const isIOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/) // ios終端
      html2canvas(this.$refs.pdfDom, {
        allowTaint: true,
        y: isIOS ? 200 : 0
      })

      html2canvas(this.$refs.pdfDom, {allowTaint: true,y: isIOS ? 200 : 0})
        .then((canvas) => {
          const contentWidth = canvas.width
          const contentHeight = canvas.height
          const pageHeight = contentWidth / 592.28 * 841.89
          let leftHeight = contentHeight
          let position = 0
          const imgWidth = 595.28
          const imgHeight = 592.28 / contentWidth * contentHeight
          const pageData = canvas.toDataURL('image/jpeg', 1.0)
          const PDF = new JsPDF('', 'pt', 'a4')
          // 有兩個(gè)高度需要區(qū)分,一個(gè)是html頁面的實(shí)際高度,和生成pdf的頁面高度(841.89)
          // 當(dāng)內(nèi)容未超過pdf一頁顯示的范圍,無需分頁
          if (leftHeight < pageHeight) {
            PDF.addImage(pageData, 'JPEG', 0, 0, imgWidth, imgHeight)
          } else { // 分頁
            while (leftHeight > 0) {
              // 在pdf.addImage(pageData, 'JPEG', 左,上,寬度,高度)設(shè)置在pdf中顯示;
              PDF.addImage(pageData, 'JPEG', 0, position, imgWidth, imgHeight)
              leftHeight -= pageHeight
              position -= 841.89
              if (leftHeight > 0) {
                PDF.addPage()
              }
            }
          }
          PDF.save(title + '.pdf')
        })
    }
  }
}
</script>
<style scoped lang="less">
  .get-pdf{
    width: 100vw;
    height: 160px;
    background: #FFFFFF;
    box-shadow: 0px 2px 0px 0px #F5F5F5;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 40px;
    /*position: fixed;*/
    /*bottom: 0;*/
    &>div{
      width: 90vw;
      height: 100px;
      background: #4475D6;
      border-radius: 8px;
      text-align: center;
      line-height: 100px;
      font-size: 36px;
      font-weight: 500;
      color: #FFFFFF;
    }
  }
</style>

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue結(jié)合ElementUI上傳Base64編碼后的圖片實(shí)例

    Vue結(jié)合ElementUI上傳Base64編碼后的圖片實(shí)例

    這篇文章主要介紹了Vue結(jié)合ElementUI上傳Base64編碼后的圖片實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue下history模式刷新后404錯(cuò)誤解決方法

    vue下history模式刷新后404錯(cuò)誤解決方法

    這篇文章主要介紹了vue下history模式刷新后404錯(cuò)誤解決方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-08-08
  • vue中各組件之間傳遞數(shù)據(jù)的方法示例

    vue中各組件之間傳遞數(shù)據(jù)的方法示例

    Vue 的組件作用域都是孤立的,不允許在子組件的模板內(nèi)直接引用父組件的數(shù)據(jù)。必須使用特定的方法才能實(shí)現(xiàn)組件之間的數(shù)據(jù)傳遞。下面這篇文章主要給大家介紹了關(guān)于vue中各組件之間傳遞數(shù)據(jù)的方法示例,需要的朋友可以參考學(xué)習(xí)。
    2017-07-07
  • vue-cli實(shí)現(xiàn)多頁面多路由的示例代碼

    vue-cli實(shí)現(xiàn)多頁面多路由的示例代碼

    本篇文章主要介紹了vue-cli實(shí)現(xiàn)多頁面多路由的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-01-01
  • axios中post請(qǐng)求json和application/x-www-form-urlencoded詳解

    axios中post請(qǐng)求json和application/x-www-form-urlencoded詳解

    Axios是專注于網(wǎng)絡(luò)數(shù)據(jù)請(qǐng)求的庫,相比于原生的XMLHttpRequest對(duì)象,axios簡單易用,下面這篇文章主要給大家介紹了關(guān)于axios中post請(qǐng)求json和application/x-www-form-urlencoded的相關(guān)資料,需要的朋友可以參考下
    2022-10-10
  • Element el-upload上傳組件使用詳解

    Element el-upload上傳組件使用詳解

    本文主要介紹了Element el-upload上傳組件使用詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • 詳解Vue路由自動(dòng)注入實(shí)踐

    詳解Vue路由自動(dòng)注入實(shí)踐

    這篇文章主要介紹了詳解Vue路由自動(dòng)注入實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • elementUI中el-upload文件上傳的實(shí)現(xiàn)方法

    elementUI中el-upload文件上傳的實(shí)現(xiàn)方法

    ElementUI的組件支持多種事件鉤子,如http-request、before-upload和on-change,以實(shí)現(xiàn)自定義文件上傳處理,這篇文章主要介紹了elementUI中el-upload文件上傳的實(shí)現(xiàn)方法,需要的朋友可以參考下
    2024-11-11
  • element-ui 文件上傳修改文件名的方法示例

    element-ui 文件上傳修改文件名的方法示例

    這篇文章主要介紹了element-ui 文件上傳修改文件名的方法示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • vue中過濾器filter的講解

    vue中過濾器filter的講解

    今天小編就為大家分享一篇關(guān)于vue中過濾器filter的講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-01-01

最新評(píng)論