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

vue實現(xiàn)在線預覽office文件的示例代碼

 更新時間:2021年10月22日 09:49:41   作者:流浪碼農~  
本文主要介紹了vue實現(xiàn)在線預覽office文件,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

最近在做電子檔案,后端提供了文件的華為云的oss鏈接。已經實現(xiàn)了點擊下載文件的功能。但是呢,他們又希望常規(guī)的文件,可以直接點擊預覽,不需要下載。

按道理說,做文件的在線預覽,買個第三方服務什么的,后端部署一下服務,前端對接一下,就通通搞定。
頂不住第三方基本上是要money的。那不想掏money,還有什么解決方法呢。

方法一

用微軟的office online進行在線預覽

https://view.officeapps.live.com/op/view.aspx?src=文件地址
例:https://view.officeapps.live.com/op/view.aspx?src=http://www.xxx.com/xxx.ppt

方法二

用docx云服務的在線預覽,用法跟微軟差不多

http://view.xdocin.com/xdoc?_xdoc=文件地址

前提是后端提供的文件地址是要公開可訪問的鏈接,比如我們這里是將文件上傳到華為云的。文件只支持查看,不能編輯。

效果如下

在這里插入圖片描述

在這里插入圖片描述

在這里插入圖片描述

上代碼

    <!-- 預覽圖標 -->
                  <i
                    v-if="row.doc_url && canPreviewList.includes(row.doc_ext)"
                    style="font-weight: bold;font-size:16px;"
                    class="link-type el-icon-view"
                    @click.stop="previewFileEvent(row)"
                  />
    previewFileEvent(row) {
      const typeArr = ['doc', 'docx', 'ppt', 'pptx', 'xls', 'xlsx']
      let url = ''
      if (typeArr.indexOf(row.doc_ext) !== -1) {
        // 使用微軟的office online
        url = 'http://view.officeapps.live.com/op/view.aspx?src=' + row.doc_url
      } else {
        url = row.doc_url
      }
      // window.open()居中打開
      const width = 1000; const height = 800
      const top = (window.screen.availHeight - height) / 2
      const left = (window.screen.availWidth - width) / 2
      window.open(url, '', 'width=' + width + ',height=' + height + ',top=' + top + ',left=' + left)
    }

我這里使用的是微軟提供的服務??梢杂脕泶蜷_'doc', ‘docx', ‘ppt', ‘pptx', ‘xls', 'xlsx'文件。
對其他文件做了一些處理,比如pdf,圖片文件這些是可以直接通過鏈接打開的,瀏覽器支持直接預覽。
而其他文件無法預覽的,我這里做了限制,不讓預覽圖標顯示出來。

這里遇到個問題,txt文件,直接在瀏覽器打開是亂碼的。下載下來是正常的,沒找到解決方法。
有大佬知道的,帶帶。O(∩_∩)O

txt文件亂碼的原因找到了。跟瀏覽器的編碼格式有關。

我這里的txt文件,保存的時候是utf-8編碼。但是谷歌瀏覽器默認的不是。

在這里插入圖片描述

要修改成對應的編碼格式,顯示才會正常。

修改谷歌瀏覽器編碼格式,需求到應用商店安裝一個官方插件Set Character Encoding
安裝完后,在頁面右鍵點擊修改編碼格式即可。

在這里插入圖片描述

到此這篇關于vue實現(xiàn)在線預覽office文件的示例代碼的文章就介紹到這了,更多相關vue 在線預覽office 內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue3 攜帶參數跳轉|router傳參方式

    vue3 攜帶參數跳轉|router傳參方式

    這篇文章主要介紹了vue3 攜帶參數跳轉|router傳參方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • webpack+vuex+axios 跨域請求數據的示例代碼

    webpack+vuex+axios 跨域請求數據的示例代碼

    本篇文章主要介紹了webpack+vuex+axios 跨域請求數據,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • 詳解vue-cli3 中跨域解決方案

    詳解vue-cli3 中跨域解決方案

    這篇文章主要介紹了vue-cli3 中跨域解決方案,非常不錯,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-04-04
  • 淺析從vue源碼看觀察者模式

    淺析從vue源碼看觀察者模式

    本篇文章主要介紹了vue源碼看觀察者模式,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • elementUI如何動態(tài)給el-tree添加子節(jié)點數據children詳解

    elementUI如何動態(tài)給el-tree添加子節(jié)點數據children詳解

    element-ui 目前基本成為前端pc網頁端標準ui框架,下面這篇文章主要給大家介紹了關于elementUI如何動態(tài)給el-tree添加子節(jié)點數據children的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-11-11
  • Vuex模塊化和命名空間namespaced實例演示

    Vuex模塊化和命名空間namespaced實例演示

    這篇文章主要介紹了Vuex模塊化和命名空間namespaced的相關知識,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-11-11
  • 使用Axios攔截器中止Vue請求的步驟詳解

    使用Axios攔截器中止Vue請求的步驟詳解

    假設?App?的用戶可以在短時間內進行多個?API?調用,但您只想顯示上次調用的結果,之前正在進行的請求變得無關緊要,在這種情況下,您可以利用?Axios?攔截器,本文給大家介紹了如何使用Axios攔截器中止Vue請求,需要的朋友可以參考下
    2023-11-11
  • v-if 導致 elementui 表單校驗失效問題解決方案

    v-if 導致 elementui 表單校驗失效問題解決方案

    在使用 elementui 表單的過程中,某些表單項需要通過 v-if 來判斷是否展示,但是這些表單項出現(xiàn)了檢驗失效的問題,今天小編給大家介紹v-if 導致 elementui 表單校驗失效問題解決方案,感興趣的朋友一起看看吧
    2024-01-01
  • ant-design-vue table分頁onShowSizeChange后的pageNo解決

    ant-design-vue table分頁onShowSizeChange后的pageNo解決

    這篇文章主要介紹了ant-design-vue table分頁onShowSizeChange后的pageNo的問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 詳解vue+css3做交互特效的方法

    詳解vue+css3做交互特效的方法

    本篇文章主要介紹了詳解vue+css3做交互特效的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11

最新評論