vue 文件预览mp4、txt、pptx、xls、xlsx、docx、pdf、html、xml

vue 文件预览 图片、mp4、txt、pptx、xls、xlsx、docx、pdf、html、xml

最近公司要做一个类似电脑文件夹的功能,支持文件夹操作,文件操作,这里就不说文件夹操作了,说说文件预览操作,本人是后端java开发,前端vue,目前没有人,就也由我来写,直接上代码(我的文件是上传到OSS上的,预览远程文件的话需要配置好跨域)

图片就简单了,直接打开新的窗口

复制代码
window.open(url,'_blank')

视频也是一样的,直接打开新的窗口

复制代码
window.open(url,'_blank')

docx

复制代码
这里使用的是vue-office组件,先安装依赖
 ----------------------------------------
 
#docx文档预览组件
npm install @vue-office/docx vue-demi@0.14.6
--------------------------------------------------------
页面中引入组件
//引入VueOfficeDocx组件
import VueOfficeDocx from '@vue-office/docx'
//引入相关样式
import '@vue-office/docx/lib/index.css'

<script>
	export default {
	  components:{
	    VueOfficeDocx
	  },
</script>
<template>
	<vue-office-docx
	            class="show_office"
	            :src="docxUrl"
	            style="height: 90vh;"
	          />
 </template>

excel

复制代码
这里使用的是vue-office组件,先安装依赖
 ----------------------------------------
 
#excel文档预览组件
npm install @vue-office/excel vue-demi@0.14.6

--------------------------------------------------------
页面中引入组件

//引入VueOfficeExcel组件
import VueOfficeExcel from '@vue-office/excel'
//引入相关样式
import '@vue-office/excel/lib/index.css'

<script>
export default {
  components:{
    VueOfficeExcel
  },
</script>

<template>
 <vue-office-excel
            class="show_office"
            :src="excelUrl"
            style="height: 90vh;"
          />
</template>

pdf

复制代码
这里使用的是vue-office组件,先安装依赖
 ---------------------------------------
 
#pdf文档预览组件
npm install @vue-office/pdf vue-demi@0.14.6
--------------------------------------------------------
页面中引入组件

//引入VueOfficePdf组件
import VueOfficePdf from '@vue-office/pdf'

<script>
export default {
  components:{
    VueOfficePdf
  },
 </script>
 
  </template>
	  <vue-office-pdf
	            class="show_office"
	            :src="pdfUrl"
	            style="height: 90vh;"
	          />      
</template>             

txt、html

复制代码
<div
    style="width:100%;
    height: 90vh;"
    v-html="txtUrl"
    />

axios.get(url, { responseType: 'text' })
          .then(response => {
            // 根据设置的编码进行处理,这里假定utf-8
            this.txtUrl = response.data;
          })

xml

复制代码
axios.get(url, { responseType: 'text' })
          .then(response => {
            const parser = new DOMParser();
            const xmlDoc = parser.parseFromString(response.data, 'text/xml');
            this.parsedXML = new XMLSerializer().serializeToString(xmlDoc.documentElement);
          })

<pre style="width:100%;height: 90vh;"><code>{{ parsedXML }}</code></pre>

pptx

这里使用的是PPTXjs

1.下载好的PPTXjs放到public目录下

2.修改PPYXjs的index.hhtml,获取实际文件地址

3 通过拼接地址,请求PPYXjs实现预览操作

链接: https://blog.csdn.net/IAIPython/article/details/137677707

链接: https://github.com/501351981/vue-office

相关推荐
毕设十刻3 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
Source.Liu4 小时前
【PDF-rs】pdf子项目的lib.rs文件
pdf
学会用脚编程5 小时前
word转Pdf,在window正常,放在linux服务器上就转出来中文是空白
pdf·word
机器学习算法与Python实战6 小时前
最好的大模型训练、微调教程.pdf
pdf
CodeCraft Studio6 小时前
PPT处理控件Aspose.Slides教程:使用Java将PowerPoint笔记导出为PDF
java·笔记·pdf·powerpoint·aspose·ppt转pdf·java将ppt导出pdf
深蓝电商API6 小时前
告别混乱文本:基于深度学习的 PDF 与复杂版式文档信息抽取
人工智能·深度学习·pdf
王同学要变强7 小时前
【深入学习Vue丨第二篇】构建动态Web应用的基础
前端·vue.js·学习
社恐的下水道蟑螂7 小时前
从字符串到像素:深度解析 HTML/CSS/JS 的页面渲染全过程
javascript·css·html
程序定小飞7 小时前
基于springboot的web的音乐网站开发与设计
java·前端·数据库·vue.js·spring boot·后端·spring
武昌库里写JAVA7 小时前
element-ui 2.x 及 vxe-table 2.x 使用 css 定制主题
java·vue.js·spring boot·sql·学习