亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue實現(xiàn)預(yù)覽文件(Word/Excel/PDF)功能的示例代碼

 更新時間:2023年03月20日 09:40:15   作者:會說法語的豬  
這篇文章主要為大家詳細介紹了如何通過Vue實現(xiàn)預(yù)覽文件(Word/Excel/PDF)的功能,文中的實現(xiàn)步驟講解詳細,需要的小伙伴可以參考一下

之前也有寫過兩篇預(yù)覽pdf的,但好像還沒寫過預(yù)覽word和excel的,但是這次的預(yù)覽pdf和之前的三個又不一樣!使用pdfobject預(yù)覽pdf ,Vue使用vue-pdf實現(xiàn)PDF文件預(yù)覽,Vue使用pdf-lib為文件流添加水印并預(yù)覽,這是之前寫的三篇,大家有興趣也可以去看看,總會有一個適合的!

這次剛找到三個兄弟庫,分別是預(yù)覽word、Excel、pdf文檔的,用著很好用,但是word這個好像是有點兒bug但還不確定,因為有的能加載出來有的加載不出來,還需要驗證。其他兩個應(yīng)該是沒什么問題的,使用起來也很簡單,下面來介紹一下:

安裝 

//docx文檔預(yù)覽組件
npm install @vue-office/docx vue-demi
 
//excel文檔預(yù)覽組件
npm install @vue-office/excel vue-demi
 
//pdf文檔預(yù)覽組件
npm install @vue-office/pdf vue-demi

引入組件、注冊 

引入進來是個組件,注冊一下就可以直接使用了 

// docx文檔引入、注冊
import VueOfficeDocx from '@vue-office/docx'
import '@vue-office/docx/lib/index.css'
 

export default {
  components: { VueOfficeDocx }
}

 
 
// excel文檔引入、注冊
import VueOfficeExcel from '@vue-office/excel'
import '@vue-office/excel/lib/index.css'
 

export default {
  components: { VueOfficeDocx }
}

 
// pdf文檔引入、注冊
import VueOfficePdf from '@vue-office/pdf'
 

export default {
  components: { VueOfficeDocx }
}

其實都是一樣的,很簡單!

使用

使用的時候,我們直接使用上面注冊的組件,然后給其src復(fù)制就可以了,src就是我們要預(yù)覽的文件的路徑,文件路徑其實也有很多種方式,我這里提供三種方式,分別是通過1、window.URL.createObjectURL將文件流Blob對象轉(zhuǎn)為一個路徑。2、通過FileReader類來進行加載獲取base64編碼等。3、通過調(diào)用Blob對象的arrayBuffer方法獲取到文件的buffer進行賦值。

下面直接上完整代碼了,大家稍微一看都懂啦。我這里測試的還是從本地選擇的文件,從服務(wù)器獲取文件也是一樣的,設(shè)置responseType為"blob",返回的也就是文件流Blob對象,操作其實是一樣的,我示例中給src賦值的方式給出了三種,到時候選擇一種用就可以了。下面上完整代碼: 

<template>
  <div class="index">
    <div class="select-file">
      <input id="input" type="file">
    </div>
    <div class="file-preview">
      <!-- <VueOfficeDocx v-if="src" style="height: 600px;" :src="src" /> -->
      <!-- <VueOfficeExcel v-if="src" style="height: 600px;" :src="src" /> -->
      <VueOfficePdf v-if="src" style="height: 600px;" :src="src" />
    </div>
  </div>
</template>
<script>
import VueOfficeDocx from '@vue-office/docx'
import '@vue-office/docx/lib/index.css'
 
import VueOfficeExcel from '@vue-office/excel'
import '@vue-office/excel/lib/index.css'
 
import VueOfficePdf from '@vue-office/pdf'
export default {
  data() {
    return {
      src: ''
    }
  },
  components: { VueOfficeDocx, VueOfficeExcel, VueOfficePdf },
  mounted() {
    this.addInputEventListener()
  },
  methods:{
    /**
     * application/msword;charset=utf-8
     * application/pdf;charset=utf-8
     * application/vnd.ms-excel
     */
    addInputEventListener() {
      const input = document.querySelector('#input')
      input.addEventListener('input', e => {
        const fileBlob = e.target.files[0]
 
        // 第一種方式(通過window.URL.createObjectURL將Blob文件流轉(zhuǎn)為一個路徑)
        this.src = window.URL.createObjectURL(new Blob([fileBlob]))
 
        // 第二種方式(轉(zhuǎn)為base64編碼)
        const fileReader = new FileReader()
        fileReader.readAsDataURL(fileBlob)
        fileReader.onload = e => {
          this.src = e.target.result
        }
        
        // 第三種方式(獲取到buffer)
        fileBlob.arrayBuffer().then(buffer => {
          this.src = buffer
        })
      })
    }
  }
}
</script>
<style scoped>
.index {
  width: 100%;
  height: 100%;
  padding: 15px;
  box-sizing: border-box;
}
.select-file {
  width: 100%;
  height: 35px;
  border-bottom: 1px dashed #ccc;
  margin-bottom: 15px;
}
.file-preview {
  width: 100%;
  height: 650px;
  border: 1px dashed #007acc;
}
</style>

以上就是Vue實現(xiàn)預(yù)覽文件(Word/Excel/PDF)功能的示例代碼的詳細內(nèi)容,更多關(guān)于Vue預(yù)覽文件的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Vue中mixins的使用方法詳解

    Vue中mixins的使用方法詳解

    mixins是一種分發(fā) Vue 組件中可復(fù)用功能的使用方式,它是一個 js 對象,包含我們組件script中的任意功能選項,下面就跟隨小編一起來看看它的具體使用吧
    2024-03-03
  • vue使用vite配置跨域以及環(huán)境配置詳解

    vue使用vite配置跨域以及環(huán)境配置詳解

    跨域是指當(dāng)一個資源去訪問另一個不同域名或者同域名不同端口的資源時,就會發(fā)出跨域請求,下面這篇文章主要給大家介紹了關(guān)于vue使用vite配置跨域以及環(huán)境配置的相關(guān)資料,需要的朋友可以參考下
    2022-07-07
  • vue打包相關(guān)細節(jié)整理(小結(jié))

    vue打包相關(guān)細節(jié)整理(小結(jié))

    這篇文章主要介紹了vue打包相關(guān)細節(jié)整理(小結(jié)),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • Element-Plus Select組件實現(xiàn)滾動分頁加載功能

    Element-Plus Select組件實現(xiàn)滾動分頁加載功能

    Element-Plus的select組件并沒有自帶滾動分頁加載的功能,其雖然提供了自定義下拉菜單的底部的方式可以自定義上一頁及下一頁操作按鈕的方式進行分頁加載切換,這篇文章主要介紹了Element-Plus Select組件實現(xiàn)滾動分頁加載功能,需要的朋友可以參考下
    2024-03-03
  • Vue實現(xiàn)購物車場景下的應(yīng)用

    Vue實現(xiàn)購物車場景下的應(yīng)用

    這篇文章主要為大家詳細介紹了Vue實現(xiàn)購物車場景下的應(yīng)用,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • vue.js實現(xiàn)簡單的計算器功能

    vue.js實現(xiàn)簡單的計算器功能

    這篇文章主要為大家詳細介紹了vue.js實現(xiàn)簡單的計算器功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • Vue+Typescript中在Vue上掛載axios使用時報錯問題

    Vue+Typescript中在Vue上掛載axios使用時報錯問題

    這篇文章主要介紹了Vue+Typescript中在Vue上掛載axios使用時報錯問題,本文給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-08-08
  • vue中的v-touch事件用法說明

    vue中的v-touch事件用法說明

    這篇文章主要介紹了vue中的v-touch事件用法說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • vue組件父與子通信詳解(一)

    vue組件父與子通信詳解(一)

    這篇文章主要為大家詳細介紹了vue組件父與子通信詳解,實現(xiàn)登錄窗口,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • Vue渲染器設(shè)計實現(xiàn)流程詳細講解

    Vue渲染器設(shè)計實現(xiàn)流程詳細講解

    在瀏覽器平臺上,用它來渲染其中的真實DOM元素。渲染器不僅能夠渲染真實的DOM元素,它還是框架跨平臺能力的關(guān)鍵。所以在設(shè)計渲染器的時候一定要考慮好自定義的能力
    2023-01-01

最新評論