前端实现文件预览(pdf、excel、word、图片)

简介: 前端实现文件预览(pdf、excel、word、图片)

图片预览

iframe标签能够将另一个HTML页面嵌入到当前页面中,我们的图片也能够使用iframe标签来进行展示。

js

复制代码

<iframe  :src="图片地址"         style="z-index: 1000; height:650px; width: 100%; margin: 0 auto"         sandbox="allow-scripts allow-top-navigation allow-same-origin allow-popups"/>

sandbox这个属性如果是单纯预览图片可以不使用,该属性对呈现在 iframe 框架中的内容启用一些额外的限制条件。属性值可以为空字符串(这种情况下会启用所有限制),也可以是用空格分隔的一系列指定的字符串。

  • allow-scripts: 允许嵌入的浏览上下文运行脚本(但不能创建弹窗)。如果没有使用该关键字,就无法运行脚本。
  • allow-top-navigation: 允许将框架内所加载页面中的超链接导航到父级窗口
  • allow-same-popups: 允许弹窗 (例如 window.open, target="_blank")。如果没有使用该关键字,相应的功能将自动被禁用。
  • allow-same-origin: 如果没有使用该关键字,嵌入的浏览上下文将被视为来自一个独立的源,这将使 same-origin policy 同源检查失败。使用了这个属性,那么当前页面和iframe打开的页面视为同源。

word文档预览(docx)

js

复制代码

先下载npm包npm i docx-preview --save

js

复制代码

<div class="docxRef"></div><script>import { renderAsync } from'docx-preview';

functionfn() {
// 这里的res.data是 blob文件流,如果自己的不是blob文件流// 可以通过URL.createObjectURL(参数) 参数为File格式,转换为blob文件流    let blob = res.data    let childRef = document.getElementsByClassName('docxRef');    renderAsync(blob, childRef[0]) //渲染}fn()

</script>

blob文件流

预览excel文件(xlsx)

js

复制代码

下载包npm install xlsx@0.16.0

js

复制代码

<div class="xlsxClass"></div>const reader = newFileReader();
//通过readAsArrayBuffer将blob转换为ArrayBuffer对reader.readAsArrayBuffer(res.data) // 这里的res.data是blob文件流reader.onload = (event) => {  // 读取ArrayBuffer数据变成Uint8Array  var data = newUint8Array(event.target.result);  // 这里的data里面的类型和后面的type类型要对应  var workbook = XLSX.read(data, { type: "array" });  var sheetNames = workbook.SheetNames; // 工作表名称  var worksheet = workbook.Sheets[sheetNames[0]];  // var excelData = XLSX.utils.sheet_to_json(worksheet); //JSON  let html = XLSX.utils.sheet_to_html(worksheet);  document.getElementsByClassName('xlsxClass')[0].innerHTML = html};

pdf预览

js

复制代码

下载包 npm install pdfjs-dist我使用的是npm install pdfjs-dist@2.0.943版本,以下例子使用的是vue3+vite创建的项目以下例子通过canvas来渲染pdf

html

复制代码

<template>  <divclass="box">    <divclass="tool-bar">      <div>{{ pdfParams.pageNumber }} / {{ pdfParams.total }}</div>      <buttontype="primary":disabled="pdfParams.pageNumber == pdfParams.total" @click="nextPage">下一页      </button>      <buttontype="primary":disabled="pdfParams.pageNumber == 1" @click="prevPage">上一页</button>    </div>    <canvasid="pdf-render"></canvas>  </div></template>

js

复制代码

<script setup>import { onMounted, ref, reactive } from'vue'const pdfParams = reactive({
  pageNumber: 1, // 当前页  total: 0, // 总页数});// 不要定义为ref或reactive格式,就定义为普通的变量let pdfDoc = null;
// 这里必须使用异步去引用pdf文件,直接去import会报错,也不知道为什么onMounted(async ()=> {
  let pdfjs = awaitimport('pdfjs-dist/build/pdf')  let pdfjsWorker = awaitimport('pdfjs-dist/build/pdf.worker.entry')  pdfjs.GlobalWorkerOptions.workerSrc = pdfjsWorker  // 此文件位于public/test2.pdf  let url = ref('/test2.pdf')  pdfjs.getDocument(url.value).promise.then(doc => {    pdfDoc = doc    pdfParams.total = doc.numPages    getPdfPage(1)  })})// 加载pdf的某一页constgetPdfPage = (number) => {
  pdfDoc.getPage(number).then(page => {    const viewport = page.getViewport()    const canvas = document.getElementById('pdf-render')    const context = canvas.getContext('2d')    canvas.width = viewport.viewBox[2]    canvas.height = viewport.viewBox[3]    viewport.width = viewport.viewBox[2]    viewport.height = viewport.viewBox[3]    canvas.style.width = Math.floor(viewport.width) + 'px'    canvas.style.height = Math.floor(viewport.height) + 'px'    let renderContext = {      canvasContext: context,      viewport: viewport,      // 这里transform的六个参数,使用的是transform中的Matrix(矩阵)      transform: [1, 0, 0, -1, 0, viewport.height]    }    // 进行渲染    page.render(renderContext)  })}// 下一页功能constprevPage = () => {
  if(pdfParams.pageNumber > 1) {    pdfParams.pageNumber -= 1  } else {    pdfParams.pageNumber  = 1  }  getPdfPage(pdfParams.pageNumber)}// 上一页功能constnextPage = () => {
  if(pdfParams.pageNumber < pdfParams.total) {    pdfParams.pageNumber += 1  } else {    pdfParams.pageNumber = pdfParams.total  }  getPdfPage(pdfParams.pageNumber)}</script>

以上pdf代码引用文章:(54条消息) 前端pdf预览、pdfjs的使用_pdf.js_无知的小菜鸡的博客-CSDN博客

pdfjs官方代码:例子 (mozilla.github.io)

以上代码看不懂的地方可以查阅官方代码,大部分都是固定的写法。

以上注意点:

  • 必须异步引用pdf的文件!!!
  • pdf演示文件位于public/test2.pdf
  • transform: [1, 0, 0, -1, 0, viewport.height],使用了transform中的Matrix(矩阵)
  • 下一页和上一页功能都需要重新渲染


相关文章
|
7天前
|
文字识别 BI
【图片型PDF】批量识别扫描件PDF指定区域局部位置内容,将识别内容导出Excel表格或批量改名文件,基于阿里云OCR对图片型PDF识别改名案例实现
在医疗和政务等领域,图片型PDF文件(如病历、报告、公文扫描件)的处理需求广泛。通过OCR技术识别这些文件中的文字信息,提取关键内容并保存为表格,极大提高了信息管理和利用效率。本文介绍一款工具——咕嘎批量OCR系统,帮助用户快速处理图片型PDF文件,支持区域识别、内容提取、导出表格及批量改名等功能。下载工具后,按步骤选择处理模式、进行区域采样、批量处理文件,几分钟内即可高效完成数百个文件的处理。
49 8
|
2月前
|
人工智能 自然语言处理 JavaScript
Univer:开源全栈 AI 办公工具,支持 Word、Excel、PPT 等文档处理和多人实时协作
Univer 是一款开源的 AI 办公工具,支持 Word、Excel 等文档处理的全栈解决方案。它具有强大的功能、高度的可扩展性和跨平台兼容性,适用于个人和企业用户,能够显著提高工作效率。
182 8
Univer:开源全栈 AI 办公工具,支持 Word、Excel、PPT 等文档处理和多人实时协作
|
2月前
|
JavaScript
jquery图片和pdf文件预览插件
EZView.js是一款jquery图片和pdf文件预览插件。EZView.js可以为图片和pdf格式文件生成在线预览效果。支持的文件格式有pdf、jpg、 png、jpeg、gif。
75 16
|
3月前
|
Java API Apache
Java编程如何读取Word文档里的Excel表格,并在保存文本内容时保留表格的样式?
【10月更文挑战第29天】Java编程如何读取Word文档里的Excel表格,并在保存文本内容时保留表格的样式?
207 5
|
4月前
|
前端开发 JavaScript API
前端基于XLSX实现数据导出到Excel表格,以及提示“文件已经被损坏,无法打开”的解决方法
前端基于XLSX实现数据导出到Excel表格,以及提示“文件已经被损坏,无法打开”的解决方法
335 0
|
4月前
|
前端开发
PDF文件上传转成base64编码并支持预览
PDF文件上传转成base64编码并支持预览
233 12
|
4月前
|
存储 前端开发 JavaScript
🚀前端轻松实现网页内容转换:一键复制、保存图片及生成 Markdown
在现代前端开发中,提升用户的交互体验至关重要。本文将详细介绍如何使用 HTML2Canvas 和 Turndown 两个强大的 JavaScript 库,实现将网页选中文本转化为图片并保存或复制到剪贴板,或将内容转换为 Markdown 格式。文章包含核心代码实现、技术细节和功能拓展方向,为开发者提供了一个轻量级的解决方案,提升用户体验。
352 68
|
4月前
|
前端开发 小程序 Java
java基础:map遍历使用;java使用 Patten 和Matches 进行正则匹配;后端传到前端展示图片三种情况,并保存到手机
这篇文章介绍了Java中Map的遍历方法、使用Pattern和matches进行正则表达式匹配,以及后端向前端传输图片并保存到手机的三种情况。
50 1
|
4月前
|
前端开发 JavaScript Java
导出excel的两个方式:前端vue+XLSX 导出excel,vue+后端POI 导出excel,并进行分析、比较
这篇文章介绍了使用前端Vue框架结合XLSX库和后端结合Apache POI库导出Excel文件的两种方法,并对比分析了它们的优缺点。
1558 0
|
4月前
|
JavaScript 前端开发 Python
django接收前端vue传输的formData图片数据
django接收前端vue传输的formData图片数据
87 4

热门文章

最新文章

  • 1
    【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
  • 2
    【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
  • 3
    【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
  • 4
    详解智能编码在前端研发的创新应用
  • 5
    巧用通义灵码,提升前端研发效率
  • 6
    智能编码在前端研发的创新应用
  • 7
    【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
  • 8
    【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
  • 9
    抛弃node和vscode,如何用记事本开发出一个完整的vue前端项目
  • 10
    大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡