您现在的位置是:首页 > 技术教程 正文

前端vue3实现本地及在线文件预览(含pdf/txt/mp3/mp4/docx/xlsx/pptx)

admin 阅读: 2024-03-26
后台-插件-广告管理-内容页头部广告(手机)

一、仅需实现在线预览,且文件地址公网可访问

(一)微软office免费预览(推荐

支持doc/docx/xls/xlsx/ppt/pptx等多种office文件格式的免费预览

  1. //示例代码
  2. //​在https://view.officeapps.live.com/op/view.aspx?src=后面拼接需要预览的地址,如下:\
  3. let url="http://xxx.com/files/demo.doc"
  4. window.open("​https://view.officeapps.live.com/op/view.aspx?src="https://blog.csdn.net/Sylvasylva/article/details/+encodeURIComponent(​url))

(二)XDOC文档预览云服务

 移动端和PC端无插件预览PDF、OFD、Word、WPS等多种格式文档

  1. //示例
  2. let url="http://xxx.com/files/demo.doc"
  3. window.open("https://view.xdocin.com/view?src="https://blog.csdn.net/Sylvasylva/article/details/ + encodeURIComponent(url))

二、本地及非公网文件在线预览

本地或内网预览需要借助插件实现,pdf、mp3、mp4等主要靠原生标签或浏览器自带功能,尽量减少了插件的安装

(一)pdf、txt

直接使用ifrem嵌入页面,用浏览器自带预览功能满足基本需求,其他也可以试试vue-office的pdf插件

pdf预览效果

txt预览效果

(二)mp3、mp4

使用原生audio和video标签能满足基本需求,如有其他功能的需要可以使用video.js等插件

mp3预览效果

mp4预览效果

(三)docx、xlsx

vue-office/docx和vue-office/excel对docx和xlsx文件预览,个人感觉实现上更方便,更多实现方式也可自行查询,案例很多此处就不再列出示例代码

docx预览效果

xlsx预览效果

pdf/txt/mp3/mp4/docx/xlsx及图片示例代码:
  1. <script lang="ts" setup>
  2. import { ref } from "vue";
  3. import { getImgPath } from "@/api/testApi";
  4. import VueOfficeDocx from "@vue-office/docx"; //引入docx预览插件
  5. import "@vue-office/docx/lib/index.css"; //docx预览插件样式
  6. import VueOfficeExcel from "@vue-office/excel"; //引入excel预览插件
  7. import "@vue-office/excel/lib/index.css"; //引入excel预览插件样式
  8. const src = ref("");
  9. const type = ref("");
  10. // 获取后台文件,根据实际接口处理数据
  11. const getSrc = async () => {
  12. await getImgPath().then((res: any) => {
  13. let imgBlob = new Blob([res]);
  14. src.value = URL.createObjectURL(imgBlob);
  15. });
  16. };
  17. // 本地上传的文件
  18. const uploadFile = (ev: any) => {
  19. let file = ev.target.files[0];
  20. if (file.name) {
  21. src.value = URL.createObjectURL(file);
  22. }
  23. };
  24. // vueOffice渲染完成的回调
  25. const fileRendered = (e: any) => {
  26. console.log("渲染完成了", e);
  27. };
  28. // vueOffice渲染出错的回调
  29. const fileError = (e: any) => {
  30. console.log("渲染出错了", e);
  31. };
  32. script>
  33. <style lang="scss" scoped>
  34. style>

(三)pptx

pptx预览使用的是pptx.js文件

1.在pptx.js官网下载压缩包

PPTXjsicon-default.png?t=N7T8https://pptx.js.org/index.html

(1)进入官网点击下载按钮

(2)选择版本下载

2.在public文件夹中添加pptxjs依赖文件
3.在index.html中引入
  1. "stylesheet" href="/PPTXjs/css/pptxjs.css" />
  2. <link rel="stylesheet" href="/PPTXjs/css/nv.d3.min.css" />
  3. <script
  4. type="text/javascript"
  5. src="/PPTXjs/js/jquery-1.11.3.min.js"
  6. >script>
  7. <script type="text/javascript" src="/PPTXjs/js/jszip.min.js">script>
  8. <script type="text/javascript" src="/PPTXjs/js/filereader.js">script>
  9. <script type="text/javascript" src="/PPTXjs/js/d3.min.js">script>
  10. <script type="text/javascript" src="/PPTXjs/js/nv.d3.min.js">script>
  11. <script type="text/javascript" src="/PPTXjs/js/pptxjs.js">script>
  12. <script type="text/javascript" src="/PPTXjs/js/divs2slides.js">script>
4.在页面中使用 
  1. <script lang="ts" setup>
  2. const pptxShow = (src: any) => {
  3. nextTick(() => {
  4. $("#pptx").pptxToHtml({
  5. pptxFileUrl: src, //pptx文件地址
  6. slidesScale: "100%",
  7. });
  8. });
  9. script>
  10. <style lang="scss" scoped>
  11. style>
pptx预览效果

pptx预览时注意:页面报Uncaught (in promise) TypeError: $(...).pptxToHtml is not a function的错误,检查在index.html中引入的jequry版本是否与项目中其他地方使用的版本冲突导致,选择保留一个版本即可。

如果以上内容对你有帮助,就点个赞加入收藏吧~~

标签:
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

在线投稿:投稿 站长QQ:1888636

后台-插件-广告管理-内容页尾部广告(手机)
关注我们

扫一扫关注我们,了解最新精彩内容

搜索
排行榜