前端文件预览docx、pptx和xlsx

最近做文件预览,docx、pptx和xlsx的格式,这里记录一下技术要点和参考文章。

1.插件选择: 用docx-preview \ ppt-preview \ exceljs handsontable @handsontable/vue就可以,其他的插件对于excel来说不是很方便,比如微软相关的插件就有点大了,不灵活。至于 ppt-preview ,一般也不用其他插件来做。docx-preview这个倒是有替代性强一些的。

2.要点,需要注意使用async await来读取文件,尤其是exceljs 的导入文件。其他的不用这个倒也能正常读取。一般 type是普通二进制即可,不用特别指明是xls还是doc这种文件类型。

3.handsontable @handsontable/vue在使用时需要用

import { HotTable } from "@handsontable/vue";

import Handsontable from "handsontable";

import "handsontable/dist/handsontable.full.min.css"; 引入样式和两个插件。两个都引入然后注册HotTable components: { HotTable },然后使用

复制代码
<hot-table ref="table" :settings="hotSettings"></hot-table>

其中使用时参数有两种设置方式,建议用这种就可以了。settings是json的,用的时候要注意vue2对json的双向绑定是不做深层次的,需要ref="table"拿到实例,使用hotInstance.updateSettings来手动进行数据更新。

4.handsontable @handsontable/vue有license文字的显示,需要设置关闭licenseKey: "non-commercial-and-evaluation",,我这里是内网开发,手敲的,可能会错误,需要多检查。一般外网开发不会这么惨。

5.插件需要传入dom,用vue2的$efs进行获取,对于docx和pptx的dom,需要用v-show进行控制显隐,用v-if会被销毁,影响绑定。对于xlsx,用v-if进行控制,强制进行重绘。

6.https://ost.51cto.com/posts/13656

https://www.cnblogs.com/jocongmin/p/18656478

https://github.com/handsontable/vue-handsontable-official

https://blog.csdn.net/weixin_52507110/article/details/139528572

https://yr7ywq.smartapps.baidu.com/?_chatQuery=vue使用handsontable\&searchid=9833a33e001e108d\&_chatParams={"agent_id"%3A"c816"%2C"content_build_id"%3A"b98d268"%2C"from"%3A"q2c"%2C"token"%3A"UGlGZHdpN0lzYXNVbS9Gb1JoeVNNWXRmOGI3Q0R2VFNVZlJSWlMzOW9STHY0ZmdiME5MTks3UmZZeEJaQ243OXAxQUVnZEFWR1VlWHR1SXVhMmJqRjZjcGFVZXdGdlltbjRCTXFReXE4b1JVcUVhanZoOHp1RUdNbTZ4MmZTL0k%3D"%2C"chat_no_login"%3Atrue}\&_swebScene=3711000610001000

https://zetcode.com/javascript/handsontable/

https://develop365.gitlab.io/office-viewer/pptx-preview/zh.html#codeBox1

https://501351981.github.io/pptx-preview/#:\~:text=The pure front-end preview library pptx preview for,the introduction of npm mode 纯前端实现的pptx.js文件的预览库,支持npm方式安装,支持ES Module方式引入。 在线演示

相关推荐
elseif1238 分钟前
【Markdown】指南(上)
linux·开发语言·前端·javascript·c++·笔记
钛态19 分钟前
Flutter for OpenHarmony:shelf_web_socket 快速构建 WebSocket 服务端,实现端到端实时通信(WebSocket 服务器) 深度解析与鸿蒙适配指南
服务器·前端·websocket·flutter·华为·性能优化·harmonyos
紫_龙21 分钟前
最新版vue3+TypeScript开发入门到实战教程之组件通信之二
前端·javascript·typescript
英俊潇洒美少年27 分钟前
Vue3 响应式 + 编译优化 + Diff 三者如何配合工作
前端
英俊潇洒美少年27 分钟前
Vue3 完整渲染流程(从 createApp → mount → update → unmount)
前端·javascript·vue.js
前端Hardy33 分钟前
Pinia 比 Vuex 好用 10 倍?Vue3 状态管理终于不折磨人了!(新手复制即用)
前端·javascript·vue.js
前端Hardy40 分钟前
Vue3 的 v-model 双向绑定,90% 的人都用错了?(附 2026 最新避坑指南)
前端·javascript·vue.js
前端Hardy41 分钟前
救命!Vue3 的 Composition API,居然能让我少写 80% 冗余代码?(新手也能直接抄)
前端·javascript·vue.js
李剑一43 分钟前
前端必懂!一文搞懂 WebAssembly:Web/Electron/RN 全通用,你天天用的软件,底层都靠它
前端·webassembly
Definition1 小时前
Claude Code 能养宠物了,体验下抽卡的感觉
前端·程序员