IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 前端技术实现文件预览(word、excel、pdf、ppt、mp4、图片、文本) -> 正文阅读

[JavaScript知识库]前端技术实现文件预览(word、excel、pdf、ppt、mp4、图片、文本)

前言

因为业务需要,很多文件需要在前端实现预览,今天就来了解一下吧。

Demo地址[1]:https://zhuye1993.github.io/file-view/dist/index.html

实现方案

找了网上的实现方案,效果看起来不错,放在下面的表格里,里面有一些是可以直接通过npm在vue中引入使用。

文档格式老的开源组件替代开源组件
word(docx)mammothdocx-preview(npm)
powerpoint(pptx)pptxjspptxjs改造开发
excel(xlsx)sheetjs、handsontableexceljs(npm)、handsontable(npm)(npm)
pdf(pdf)pdfjspdfjs(npm)
图片jquery.verySimpleImageViewerv-viewer(npm)

docx文件实现前端预览

代码实现

  • 首先npm i docx-preview
  • 引入renderAsync方法
  • 将blob数据流传入方法中,渲染word文档
import?{?defaultOptions,?renderAsync?}?from?"docx-preview";
renderAsync(buffer,?document.getElementById("container"),?null,
options:?{
???????className:?string?=?"docx",?//?默认和文档样式类的类名/前缀
???????inWrapper:?boolean?=?true,?//?启用围绕文档内容渲染包装器
???????ignoreWidth:?boolean?=?false,?//?禁止页面渲染宽度
???????ignoreHeight:?boolean?=?false,?//?禁止页面渲染高度
???????ignoreFonts:?boolean?=?false,?//?禁止字体渲染
???????breakPages:?boolean?=?true,?//?在分页符上启用分页
???????ignoreLastRenderedPageBreak:?boolean?=?true,//禁用lastRenderedPageBreak元素的分页
???????experimental:?boolean?=?false,?//启用实验性功能(制表符停止计算)
???????trimXmlDeclaration:?boolean?=?true,?//如果为真,xml声明将在解析之前从xml文档中删除
???????debug:?boolean?=?false,?//?启用额外的日志记录
???}
);

复制代码

实现效果

在这里插入图片描述

pdf实现前端预览

代码实现

  • 首先npm i pdfjs-dist
  • 设置PDFJS.GlobalWorkerOptions.workerSrc的地址
  • 通过PDFJS.getDocument处理pdf数据,返回一个对象pdfDoc
  • 通过pdfDoc.getPage单独获取第1页的数据
  • 创建一个dom元素,设置元素的画布属性
  • 通过page.render方法,将数据渲染到画布上
import?*?as?PDFJS?from?"pdfjs-dist/legacy/build/pdf";
//?设置pdf.worker.js文件的引入地址
PDFJS.GlobalWorkerOptions.workerSrc?=?require("pdfjs-dist/legacy/build/pdf.worker.entry.js");
//?data是一个ArrayBuffer格式,也是一个buffer流的数据
PDFJS.getDocument(data).promise.then(pdfDoc=>{
????const?numPages?=?pdfDoc.numPages;?//?pdf的总页数
????//?获取第1页的数据
????pdfDoc.getPage(1).then(page?=>{
?????//?设置canvas相关的属性
?????const?canvas?=?document.getElementById("the_canvas");
?????const?ctx?=?canvas.getContext("2d");
?????const?dpr?=?window.devicePixelRatio?||?1;
?????const?bsr?=
???????ctx.webkitBackingStorePixelRatio?||
???????ctx.mozBackingStorePixelRatio?||
???????ctx.msBackingStorePixelRatio?||
???????ctx.oBackingStorePixelRatio?||
???????ctx.backingStorePixelRatio?||
???????1;
?????const?ratio?=?dpr?/?bsr;
?????const?viewport?=?page.getViewport({?scale:?1?});
?????canvas.width?=?viewport.width?*?ratio;
?????canvas.height?=?viewport.height?*?ratio;
?????canvas.style.width?=?viewport.width?+?"px";
?????canvas.style.height?=?viewport.height?+?"px";
?????ctx.setTransform(ratio,?0,?0,?ratio,?0,?0);
?????const?renderContext?=?{
???????canvasContext:?ctx,
???????viewport:?viewport,
?????};
?????//?数据渲染到canvas画布上
?????page.render(renderContext);
????})
})

复制代码

实现效果

在这里插入图片描述

excel实现前端预览

代码实现

  • 下载exceljs、handsontable的库
  • 通过exceljs读取到文件的数据
  • 通过workbook.getWorksheet方法获取到每一个工作表的数据,将数据处理成一个二维数组的数据
  • 引入@handsontable/vue的组件HotTable
  • 通过settings属性,将一些配置参数和二维数组数据传入组件,渲染成excel样式,实现预览
//?加载excel的数据
(new?ExcelJS.Workbook().xlsx.load(buffer)).then(workbook=>{
???//?获取excel的第一页的数据
???const?ws?=?workbook.getWorksheet(1);
???//?获取每一行的数据
???const?data?=?ws.getRows(1,?ws.actualRowCount);
?})
?
?
//?渲染页面
import?{?HotTable?}?from?"@handsontable/vue";
<hot-table??:settings="hotSettings"></hot-table>
hotSettings?=?{
???language:?"zh-CN",
???readOnly:?true,
???data:?this.data,
???cell:?this.cell,
???mergeCells:?this.merge,
???colHeaders:?true,
???rowHeaders:?true,
???height:?"calc(100vh?-?107px)",
???//?contextMenu:?true,
???//?manualRowMove:?true,
???//?关闭外部点击取消选中时间的行为
???outsideClickDeselects:?false,
???//?fillHandle:?{
???//???direction:?'vertical',
???//???autoInsertRow:?true
???//?},
???//?afterSelectionEnd:?this.afterSelectionEnd,
???//?bindRowsWithHeaders:?'strict',
???licenseKey:?"non-commercial-and-evaluation"
}
复制代码

实现效果

在这里插入图片描述

pptx的前端预览

主要是通过jszip库,加载二进制文件,再经过一些列处理处理转换实现预览效果,实现起来比较麻烦,就不贴代码了,感兴趣的可以下载代码查看。

实现效果

在这里插入图片描述
最后:https://github.com/zhuye1993/file-view

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-01 23:16:14  更:2022-04-01 23:18:14 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 20:52:53-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码