Vue2实现docx,xlsx,pptx预览

一、docx预览

1、安装插件

npm i @js-preview/docx

2、代码中使用

html 复制代码
<template>
    <div id="docx"></div>
</template>

<script>
import jsPreviewDocx from "@js-preview/docx";
import '@js-preview/docx/lib/index.css'
export default {
    name: "JsPreviewDocxDemo",
    props:['fileUrl'],
    data(){
      return {
          myDocxPreviewer: null
      }
    },
    mounted() {
        //初始化时指明要挂载的父元素Dom节点
        this.myDocxPreviewer = jsPreviewDocx.init(document.getElementById('docx'));

//传递要预览的文件地址即可
        this.myDocxPreviewer.preview(this.fileUrl).then(()=>{
            console.log('预览完成');
        }).catch(e=>{
            console.log('预览失败', e);
        })
    },
    beforeDestroy() {
        this.myDocxPreviewer.destroy();
    }
};
</script>

<style scoped>

</style>

二、xlsx预览

1、安装插件

npm i @js-preview/excel

2、代码中使用

html 复制代码
<template>
    <div id="excel" style="height: 100%;"></div>
</template>

<script>
import jsPreviewExcel from "@js-preview/excel";
import '@js-preview/excel/lib/index.css';
export default {
    name: "JsPreviewExcelDemo",
    props:['fileUrl'],
    data(){
      return {
          myExcelPreviewer: null
      }
    },
    mounted(){
        this.myExcelPreviewer = jsPreviewExcel.init(document.getElementById('excel'));
        this.myExcelPreviewer .preview(this.fileUrl).then(()=>{
            console.log('预览完成');
        }).catch(e=>{
            console.log('预览失败', e);
        })
    },
    beforeDestroy() {
        this.myExcelPreviewer.destroy();
    }
};
</script>

<style scoped>

</style>

三、pptx预览

1、pptxjs插件下载https://github.com/meshesha/PPTXjs/releases

2、插件压缩包解压,放在项目静态资源目录下。

3、index.html中进行引用。

html 复制代码
<link rel="stylesheet" href="<%= BASE_URL %>/PPTXjs/css/pptxjs.css" rel="external nofollow" />
		<link rel="stylesheet" href="<%= BASE_URL %>/PPTXjs/css/nv.d3.min.css" rel="external nofollow" />
		<!-- for charts graphs -->
		<script type="text/javascript" src="<%= BASE_URL %>/PPTXjs/js/jquery-1.11.3.min.js"></script>
		<script type="text/javascript" src="<%= BASE_URL %>/PPTXjs/js/jszip.min.js"></script>
		<!-- v2.. , NOT v.3.. -->
		<script type="text/javascript" src="<%= BASE_URL %>/PPTXjs/js/filereader.js"></script>
		<!--https://github.com/meshesha/filereader.js -->
		<script type="text/javascript" src="<%= BASE_URL %>/PPTXjs/js/d3.min.js"></script>
		<!-- for charts graphs -->
		<script type="text/javascript" src="<%= BASE_URL %>/PPTXjs/js/nv.d3.min.js"></script>
		<!-- for charts graphs -->
		<script type="text/javascript" src="<%= BASE_URL %>/PPTXjs/js/pptxjs.js"></script>
		<script type="text/javascript" src="<%= BASE_URL %>/PPTXjs/js/divs2slides.js"></script>
		<!-- for slide show -->

4、代码中使用

html 复制代码
<div id="pptx"></div>


 mounted() {
        $("#pptx").pptxToHtml({
            pptxFileUrl: "http://127.0.0.1:5500/test.ppt", //pptx文件地址
            slidesScale: "100%",
            slideMode: false,
            keyBoardShortCut: false
        });
    }
相关推荐
liliangcsdn2 分钟前
LLM如何辅助RAG从大量文档中筛选目标文档
开发语言·人工智能
是上好佳佳佳呀6 分钟前
【前端(十二)】JavaScript 函数与对象笔记
前端·javascript·笔记
无忧.芙桃7 分钟前
C++IO库的超详细讲解
开发语言·c++
朗迹 - 张伟14 分钟前
用AI开发QT——Qt与Trae开发环境搭建
开发语言·qt·策略模式
雨辰AI17 分钟前
从 MySQL 迁移至人大金仓 V9 完整改造指南|分页 / 函数 / 语法兼容全部解决
java·开发语言·数据库·后端·mysql·政务
MATLAB代码顾问23 分钟前
改进鲸鱼优化算法(IWOA)求解柔性作业车间调度问题(FJSP)——附MATLAB代码
开发语言·算法·matlab
Rkgua27 分钟前
ESModule和Commonjs模块的区别
前端·javascript
阿里嘎多学长41 分钟前
2026-05-03 GitHub 热点项目精选
开发语言·程序员·github·代码托管
江南十四行43 分钟前
AI Agent应用类型及Function Calling开发实战(三)
服务器·前端·javascript
yqcoder1 小时前
JavaScript 数据类型全景图:从基础到进阶
开发语言·javascript·ecmascript