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

vue預(yù)覽本地pdf文件方法之vue-pdf組件使用

 更新時間:2024年03月21日 11:20:16   作者:菜鳥茜  
這篇文章主要介紹了vue預(yù)覽本地pdf文件方法之vue-pdf組件使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

1、npm安裝

npm install --save vue-pdf

2、頁面引入

3、具體實現(xiàn)

<div class="pdf" v-show="fileType === 'pdf'">
<p class="arrow">
    <span @click="changePdfPage(0)" class="turn" 
             :class="{grey: currentPage==1}">Preview</span>
    {{currentPage}} / {{pageCount}}
    <span @click="changePdfPage(1)" class="turn" 
            :class="{grey: currentPage==pageCount}">Next</span>
</p>                              
<pdf  :src="pdfSrc" :page="currentPage" @num-pages="pageCount=$event" 
        @page-loaded="currentPage=$event"   @loaded="loadPdfHandler">
</pdf>
</div>

4、method方法

// 改變PDF頁碼,val傳過來區(qū)分上一頁下一頁的值,0上一頁,1下一頁
      changePdfPage (val) {
        // console.log(val)
        if (val === 0 && this.currentPage > 1) {
          this.currentPage--
          // console.log(this.currentPage)
        }
        if (val === 1 && this.currentPage < this.pageCount) {
          this.currentPage++
          // console.log(this.currentPage)
        }
      },
 
      // pdf加載時
      loadPdfHandler (e) {
        this.currentPage = 1 // 加載的時候先加載第一頁
      },

5、完整代碼

<template>
    <div>
        <div style="text-align: left;">
        <H2>行業(yè)資料</H2>
        <el-divider>
        </el-divider>
        <el-container>
            <el-aside width="300px" style="border: 1px solid #eee;height: 1000px; background-color: #D3DCE6;">
                <div class="myTree">
                <el-tree default-expand-all :props="defaultProps" :data="tableData"  @node-click="handleNodeClick"></el-tree>
                </div>
            </el-aside>
            <el-container  style="border: 1px solid #eee;margin-left: 10px;">
                <div class="pdf" v-show="fileType === 'pdf'">
                    <p class="arrow">
                        <span :class="{grey: currentPage==1}" @click="changePdfPage(0)" class="turn">Preview</span>
                        {{currentPage}} / {{pageCount}}
                        <span :class="{grey: currentPage==pageCount}" @click="changePdfPage(1)" class="turn">Next</span>
                    </p>
                    <pdf
                            :page="currentPage"
                            :src="pdfSrc"
                            @loaded="loadPdfHandler"
                            @num-pages="pageCount=$event"
                            @page-loaded="currentPage=$event">
                    </pdf>
                </div>
            </el-container>
        </el-container>
        </div>
    </div>
</template>
<script>
  import pdf from 'vue-pdf'
 
  export default {
    name: "IndustryInformation",
    components: {pdf},
    data(){
      return {
        currentPage: 0, // pdf文件頁碼
        pageCount: 0, // pdf文件總頁數(shù)
        fileType: 'pdf', // 文件類型
        pdfSrc: '',  // pdf文件地址
        defaultProps: {
          children: 'children',
          label: 'name'
        },
 
        tableData: [{
          id: 1,
          name: '道路工程資料',
          children:[
            {
              id: 2,
              name: '公路工程資料編制概述',
              children:[
                {
                  id: 21,
                  name: '路面工程部分分項劃分表',
                  src: '/1.pdf',
                },
                {
                  id: 13,
                  name: '一般建設(shè)項目單位工程劃分表',
                  src: '/2.pdf',
                },
                {
                  id: 14,
                  name: '路基工程部分分項劃分表',
                  src: '/3.pdf',
                },
                {
                  id: 33,
                  name: '橋梁工程部分分項劃分表',
                  src: '/4.pdf',
                },
                {
                  id: 34,
                  name: '隧道工程部分分項劃分表',
                  src: '/5.pdf',
                }
              ]
            },
            {
              id: 3,
              name: '公路工程竣工資料',
              children:[
                {
                  id: 7,
                  name: '公路工程竣工文件編排層次',
                  src: '/5.pdf',
                },
                {
                  id: 8,
                  name: '工程洽商記錄表',
                  src: '/4.pdf',
                },
                {
                  id: 9,
                  name: '工程設(shè)計表更、洽商一覽表',
                  src: '/3.pdf',
                }
              ]
            }
          ]}]
      }
    },
    methods:{
      // 改變PDF頁碼,val傳過來區(qū)分上一頁下一頁的值,0上一頁,1下一頁
      changePdfPage(val) {
        // console.log(val)
        if (val === 0 && this.currentPage > 1) {
          this.currentPage--
          // console.log(this.currentPage)
        }
        if (val === 1 && this.currentPage < this.pageCount) {
          this.currentPage++
          // console.log(this.currentPage)
        }
      },
 
      // pdf加載時
      loadPdfHandler(e) {
        this.currentPage = 1 // 加載的時候先加載第一頁
      },
 
      handleNodeClick(data) {
        this.pdfSrc = data.src;
      }
 
    }
  }
</script>
<style scoped>
    .myTree /deep/ .el-tree {
        position: relative;
        cursor: default;
        color: #606266;
        background-color: #D3DCE6;
    }
</style>

6、最終效果

后記:

主要是priview和next翻頁不是我想要的效果,因此只能另尋它法。

注意:

pdf文件需要放在public路徑下任意文件夾中,不支持相對路徑

總結(jié)

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

相關(guān)文章

  • Vue infinite update loop的問題解決

    Vue infinite update loop的問題解決

    這篇文章主要介紹了Vue "...infinite update loop..."的問題解決,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-04-04
  • Vue項目中如何使用Axios封裝http請求詳解

    Vue項目中如何使用Axios封裝http請求詳解

    這篇文章主要給大家介紹了關(guān)于Vue項目中如何使用Axios封裝http請求的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者使用Vue具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • vue element-ui實現(xiàn)input輸入框金額數(shù)字添加千分位

    vue element-ui實現(xiàn)input輸入框金額數(shù)字添加千分位

    這篇文章主要介紹了vue element-ui實現(xiàn)input輸入框金額數(shù)字添加千分位,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-12-12
  • 基于Vue2實現(xiàn)動態(tài)折扣表格

    基于Vue2實現(xiàn)動態(tài)折扣表格

    這篇文章主要為大家詳細(xì)介紹了如何基于Vue2實現(xiàn)動態(tài)折扣表格,文中的示例代碼講解詳細(xì),具有一定的借鑒價值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-01-01
  • vue3中如何使用codemirror6增加代碼提示功能

    vue3中如何使用codemirror6增加代碼提示功能

    這篇文章主要給大家介紹了關(guān)于vue3中如何使用codemirror6增加代碼提示功能的相關(guān)資料,Codemirror是一個不錯的Web代碼編輯庫,可以方便簡單的集成,需要的朋友可以參考下
    2023-08-08
  • vue-cli創(chuàng)建的項目,配置多頁面的實現(xiàn)方法

    vue-cli創(chuàng)建的項目,配置多頁面的實現(xiàn)方法

    下面小編就為大家分享一篇vue-cli創(chuàng)建的項目,配置多頁面的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • Vue組件間通信方法總結(jié)(父子組件、兄弟組件及祖先后代組件間)

    Vue組件間通信方法總結(jié)(父子組件、兄弟組件及祖先后代組件間)

    這篇文章主要給大家介紹了關(guān)于Vue組件間通信的相關(guān)資料,其中包括父子組件、兄弟組件及祖先后代組件間的通信,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Vue具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • Vue實現(xiàn)實時刷新時間的功能

    Vue實現(xiàn)實時刷新時間的功能

    這篇文章主要為大家詳細(xì)介紹了如何Vue利用實現(xiàn)實時刷新時間的功能,文中的示例代碼講解詳細(xì),具有一定的借鑒價值,感興趣的小伙伴可以了解下
    2023-12-12
  • vue 使用monaco實現(xiàn)代碼高亮

    vue 使用monaco實現(xiàn)代碼高亮

    這篇文章主要介紹了vue 使用monaco實現(xiàn)代碼高亮的方法,幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下
    2021-03-03
  • vue的template模板是如何轉(zhuǎn)為render函數(shù)的過程

    vue的template模板是如何轉(zhuǎn)為render函數(shù)的過程

    Vue從template到render函數(shù)的轉(zhuǎn)換經(jīng)歷模板解析、AST構(gòu)建、優(yōu)化、生成渲染函數(shù)等步驟,首先進行詞法分析將模板拆解為tokens,再進行語法分析構(gòu)建AST,然后對AST進行靜態(tài)標(biāo)記和提升優(yōu)化,最后轉(zhuǎn)換成JavaScript渲染函數(shù),生成虛擬DOM,完成組件的渲染和更新,實現(xiàn)了模板的高效轉(zhuǎn)化
    2024-10-10

最新評論