首页 > 其他分享 >vue实现图片、pdf、xlsx、doc、docx、mp4、txt在线预览功能

vue实现图片、pdf、xlsx、doc、docx、mp4、txt在线预览功能

时间:2022-11-08 11:59:25浏览次数:79  
标签:xlsx docx vue false data fileName endsWith file true

后端返回的是文件流形式,并且在浏览器输入链接是直接下载到本地的。
文件流遇到问题可参考这个
https://blog.csdn.net/Robergean/article/details/125981195

https://www.hangge.com/blog/cache/detail_3163.html
https://www.jb51.net/article/263468.htm
https://blog.csdn.net/Marion158/article/details/111672738?spm=1001.2101.3001.4242.1&utm_relevant_index=3
https://gitcode.net/mirrors/gosunadeod/vue-pdf.js-demo?utm_source=csdn_github_accelerator

image
image
image
image
image
image

pdf的要下载放在本地 看你放哪里引用地址记得改
链接: https://pan.baidu.com/s/11Z5WiImWthsIRUufcyWeUA?pwd=1234 
提取码: 1234 
https://gitcode.net/mirrors/gosunadeod/vue-pdf.js-demo?utm_source=csdn_github_accelerator
npm install video.js
npm i docx-preview --save
npm install luckyexcel
//luckysheet没有npm包 所以就需要引入在index.html
//引入index.html
  <link rel='stylesheet' href='https://cdn.jsdelivr.net/npm/luckysheet@latest/dist/plugins/css/pluginsCss.css' />
  <link rel='stylesheet' href='https://cdn.jsdelivr.net/npm/luckysheet@latest/dist/plugins/plugins.css' />
  <link rel='stylesheet' href='https://cdn.jsdelivr.net/npm/luckysheet@latest/dist/css/luckysheet.css' />
  <link rel='stylesheet' href='https://cdn.jsdelivr.net/npm/luckysheet@latest/dist/assets/iconfont/iconfont.css' />
  <script src="https://cdn.jsdelivr.net/npm/luckysheet@latest/dist/plugins/js/plugin.js"></script>
  <script src="https://cdn.jsdelivr.net/npm/luckysheet@latest/dist/luckysheet.umd.js"></script>

//传入数据
file:{
	name:'xxx',
	url:'.......'
}
<template>
    <el-dialog 
        :title="file.name" 
        :visible="visible" 
        width="80%" 
        :modal-append-to-body='false'
        :close-on-press-escape='false'
        :close-on-click-modal='false'
        :before-close="handleClose" 
        style="height:auto">
        <div v-if="imgShow">
            <img :src="downloadUrl" />
        </div>
        <div v-else-if="excelShow">
            <div id="luckysheet" style="margin:0px;padding:0px;width:100%;height:500px;"></div>
        </div>
        <div v-else-if="pdfShow">
        </div>
        <div v-else-if="txtShow">
            <span>{{txtPre}}</span>
        </div>
        <div v-else-if="docShow">
            <div id="preload_box"></div>
        </div>
        <div v-else-if="pptShow">
            <div id="pptx"></div>
        </div>
        <!--视频-->
        <div v-else-if="videoShow">
            <video preload="auto" :height="500" :width="width" align="center" controls="true">
                <source :src="downloadUrl" type="video/mp4" />
            </video>
        </div>
        <!--其他不能预览的-->
        <div v-else-if="otherShow"></div>
    </el-dialog>
</template>
<script>
import Video from 'video.js';
import 'video.js/dist/video-js.css';
import { renderAsync } from 'docx-preview';
import LuckyExcel from 'luckyexcel'
export default {
    props:{
        visible:{
            type:Boolean,
            default:false
        },
        file:{
            type:Object,
            default:()=>{}
        }
    },
    data(){
        return{
            fileName: '',
            downloadUrl: '',
            imgShow: false,
            pdfShow:false,
            pptShow:false,
            txtShow:false,
            docShow: false,
            excelShow: false,
            videoShow: false,
            //其他不能预览的
            otherShow: false,
            height: window.innerHeight + 'px',
            width: '100%',
            txtPre:''
        }
    },
    created(){
        this.fileName = this.file.name
        this.downloadUrl = this.file.url
        if (this.fileName.endsWith('png') || this.fileName.endsWith('jpg') || this.fileName.endsWith('jpeg')) {
        //图片
            this.downloadUrl = this.file.url
            this.imgShow = true;
        } else if (
            this.fileName.endsWith('docx') ||
            this.fileName.endsWith('doc')
        ) {
            this.wordFn()
            this.docShow = true;
        } else if (this.fileName.endsWith('xlsx')) {
            this.excelShow = true;//调用luckysheet
        } else if (this.fileName.endsWith('mp4') || this.fileName.endsWith('mp3')) {
            this.downloadUrl = this.file.url
            this.videoShow = true;
        } else if(this.fileName.endsWith('pdf')){
            后端接口().then(res=>{
                const blob = new Blob([res.data])
                var url = window.URL.createObjectURL(blob)
                if (process.env.NODE_ENV === "production"){//判断生产环境和开发环境对应不同的路径
                    window.open('/dist/common/static/pdf/web/viewer.html?file=' + encodeURIComponent(url))
                }else{
                    window.open('/static/pdf/web/viewer.html?file=' + encodeURIComponent(url))
                }
                this.$emit('close')
            })//调用pdf查看器
            this.handleClose()
        }else if (this.fileName.endsWith('txt')){
            后端接口().then(res=>{
                let blob = new Blob([res.data]);
                blob.text().then(data =>{
                    // data:指成功读取到的内容
                    this.txtPre = data
                }).catch(err=>{
                    //err: 指读取失败后返回的错误内容
                })
            })
            this.txtShow = true
        } else {
            this.$message.error('该文件不支持在线预览!')
            this.handleClose()
        }
    },
    mounted(){
        if(this.excelShow){
            后端接口().then(res=>{
                let blob = new Blob([res.data]);
                let file = new File([blob],this.fileName,{ type: 'excel/xlsx' });
                console.log("file",file)
                LuckyExcel.transformExcelToLucky(
                    file,
                    function (exportJson,luckysheetfile) {
                        // 获得转化后的表格数据后,使用luckysheet初始化,或者更新已有的luckysheet工作簿
                        // 注:luckysheet需要引入依赖包和初始化表格容器才可以使用
                        luckysheet.create({
                            container: 'luckysheet', //luckysheet is the container id
                            showinfobar: false,
                            lang: 'zh', // 设定表格语言
                            allowEdit: false,//作用:是否允许前台编辑
                            // allowUpdate: true,
                            sheetFormulaBar: false,
                            allowCopy: true, //是否允许拷贝
                            showtoolbar: false, //是否第二列显示工具栏
                            showinfobar: false, //是否显示顶部名称栏
                            showsheetbar: true, //是否显示底部表格名称区域
                            showstatisticBar: true, //是否显示底部计数栏
                            pointEdit: false, //是否是编辑器插入表格模式
                            pointEditUpdate: null, //编辑器表格更新函数
                            data: exportJson.sheets,
                            title: exportJson.info.name,
                            userInfo: exportJson.info.name.creator,
                        });
                    },
                    function (err) {
                        logger.error('Import failed. Is your fail a valid xlsx?');
                    }
                );
                let formData = new FormData();
                formData.append('file',file);
            })
        }
    },
    methods:{
        async wordFn(){
            let res = await 后端接口()
            console.log(res.data)
            renderAsync(res.data, document.getElementById("preload_box"), null, {
                className: "docx", // 默认和文档样式类的类名/前缀
                inWrapper: true, // 启用围绕文档内容渲染包装器
                ignoreWidth: false, // 禁止页面渲染宽度
                ignoreHeight: false, // 禁止页面渲染高度
                ignoreFonts: false, // 禁止字体渲染
                breakPages: true, // 在分页符上启用分页
                ignoreLastRenderedPageBreak: true, //禁用lastRenderedPageBreak元素的分页
                experimental: false, //启用实验性功能(制表符停止计算)
                trimXmlDeclaration: true, //如果为真,xml声明将在解析之前从xml文档中删除
                debug: false, // 启用额外的日志记录
            })
        },
        handleClose(){
            this.$emit('update:visible',false)
        },
    }
}
</script>

标签:xlsx,docx,vue,false,data,fileName,endsWith,file,true
From: https://www.cnblogs.com/chaplink/p/16869174.html

相关文章

  • vue内置组件component的使用
    <keep-alive><componenttype="type":is="componentName":isEdit="isEdit":ref="componentName"@allFormSave="allFormSave":infoData="i......
  • vue 使用 js-file-download
    1、安装js-file-downloadnpminstalljs-file-download2、引入importfileDownloadfrom'js-file-download';3、使用download(){this.$api.fileDownload().......
  • Vue面试题45:history模式和hash模式有何区别?(总结自B站up主‘前端杨村长’视频,仅供自用
    分析vue-router有3个模式,其中两个更为常用,那便是history和hash;两者差别主要在显示形式和部署上;体验vue-router4.x中设置模式的方式已经改变constrouter=cr......
  • vue面试经常会问的那些题
    为什么要使用异步组件节省打包出的结果,异步组件分开打包,采用jsonp的方式进行加载,有效解决文件过大的问题。核心就是包组件定义变成一个函数,依赖import()语法,可以实现文......
  • vue面试考察知识点全梳理
    一、简介vue几个核心思想:数据驱动组件化虚拟dom、diff局部最优更新源码目录介绍Vue.js的源码在src目录下,其目录结构如下。src├──compiler#编译......
  • 一个合格的vue工程师必会的20道面试题
    params和query的区别用法:query要用path来引入,params要用name来引入,接收参数都是类似的,分别是this.$route.query.name和this.$route.params.name。url地址显示:query更......
  • vue fullcalendar月周日历
    参考https://fullcalendar.io/demoshttps://www.cnblogs.com/czk1634798848/p/13386178.htmlhttps://blog.csdn.net/qq_39863107/article/details/105387879引入了Day.......
  • Vue Router
    1.1相关理解1.1.1vue-router的理解Vue的一个插件库,专门用来实现SPA应用1.1.2对SPA应用的理解单页Web应用(singlepagewebapplication,SPA)整个应用只有一......
  • vue3-组合式api-参数(props,context)及父子组件传值
    一、父组件<template> <div>  <h2>我是父组件</h2>  <div>counter:{{counter}}</div>  <button@click="callChildFun">调用子组件方法</button> ......
  • [Typescript] 88. Hard - Simple Vue
    ImplementasimpiledversionofaVue-liketypingsupport.Byprovidingafunctionname SimpleVue (similarto Vue.extend or defineComponent),itshouldpr......