前端预览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>
相关推荐
Charlie_lll3 小时前
学习Three.js–纹理贴图(Texture)
前端·three.js
yuguo.im3 小时前
我开源了一个 GrapesJS 插件
前端·javascript·开源·grapesjs
安且惜3 小时前
带弹窗的页面--以表格形式展示
前端·javascript·vue.js
GISer_Jing5 小时前
AI驱动营销:业务技术栈实战(From AIGC,待总结)
前端·人工智能·aigc·reactjs
GIS之路6 小时前
GDAL 实现影像裁剪
前端·python·arcgis·信息可视化
AGMTI6 小时前
webSock动态注册消息回调函数功能实现
开发语言·前端·javascript
不会Android的潘潘7 小时前
受限系统环境下的 WebView 能力演进:车载平台 Web 渲染异常的根因分析与优化实践
android·java·前端·aosp
建军啊7 小时前
java web常见lou洞
android·java·前端
阳无7 小时前
宝塔部署的前后端项目从IP访问改成自定义域名访问
java·前端·部署
Galloping-Vijay7 小时前
解决 WSL2 + Windows Hosts + 开启 VPN 后无法访问本地 Web 服务的问题
前端·windows