前端预览word、excel、ppt

看到很多人都是用微软 Office Web Viewer
https://view.officeapps.live.com/op/view.aspx?src=[文件链接]

但是我们内网访问不到,不说废话了,上代码

1.预览word、excel(@vue-office/docx、@vue-office/excel)

js 复制代码
//预览word
npm i @vue-office/docx
js 复制代码
//预览excel
npm i @vue-office/excel

vue2低版本据说还要

npm install @vue/composition-api

js 复制代码
//引入VueOfficeDocx组件
import VueOfficeDocx
//引入相关样式
import '@vue-office/docx/lib/index.css'
<vue-office-docx :src="你的url" style="height: 100vh;"/>
js 复制代码
//引入VueOfficeExcel组件
import VueOfficeExcel from '@vue-office/excel'
//引入相关样式
import '@vue-office/excel/lib/index.css'
<vue-office-excel :src="你的url" style="height: 100vh"/>

2.预览ppt(pptxjs)

官网https://pptx.js.org/index.html

在pubilc里新建一个文件夹xx,拉下代码放到里面https://github.com/meshesha/PPTXjs.git

将index.html的body部分换成以下内容

这个页面作为单独预览的页面,需要接受url中的params的参数作为预览文件地址

html 复制代码
<body>
  <div id="result"></div>
  <script>
    // 创建一个URL对象  
    const urlObj = new URL(window.location.href);
    // 获取查询参数对象  
    const params = new URLSearchParams(urlObj.search);
    // 获取pptUrl参数  
    const pptUrl = params.get('pptUrl');
    $("#result").pptxToHtml({
      pptxFileUrl: pptUrl,
      slidesScale: "100%",
      slideMode: false,
      keyBoardShortCut: false
    })
  </script>
</body>
js 复制代码
  <div style="height: 100vh;" >
      <iframe
        id="iframe"
        :src="`/viewPPTX/index.html?pptUrl=${你的url}`"
        width="100%"
        height="100%"
        frameborder="0"
      ></iframe>
    </div>
相关推荐
菜鸟小九4 分钟前
html、css(javaweb第一天)
前端·css·html
y东施效颦22 分钟前
uni-app页面发布测试环境出现连接服务器超时,点击屏幕重试解决方案
前端·javascript·vue.js·uni-app·vue
大熊程序猿26 分钟前
《开篇:课程目录》
前端·c#
摸鱼仙人~1 小时前
React中子传父组件通信操作指南
前端·javascript·react.js
程序员阿超的博客1 小时前
React事件处理:如何给按钮绑定onClick点击事件?
前端·javascript·react.js
沉香亭北2 小时前
vue+vite 全局主题
前端
郑州小张2 小时前
前端解析PDF文件目录以及点击目录实现对应内容预览
前端·javascript
海底火旺2 小时前
探索扣子:解锁中间技能模块的无限可能
前端·人工智能·coze
Amctwd2 小时前
【HTML】HTML 与 CSS 基础教程
前端·css·html
快乐星球喂2 小时前
使用vant轮播组件swipe
前端