vue中实现PDF文件流预览

代码示例 

<template><div class="print"><div v-if="!viewShow" class="opt-box"><div style="height: 700px; overflow: auto;"><el-table :data="tableData" border><el-table-column prop="no" label="序号" align="center"></el-table-column><el-table-column prop="proveTypeName" label="文件名称" align="center"></el-table-column><el-table-column prop="applyTime" label="申请时间" align="center"></el-table-column><el-table-column label="操作" width="260" align="center"><template slot-scope="scope"><el-button type="text" icon="el-icon-view" @click="onChangeView(scope.row)"> 查看 </el-button></template></el-table-column></el-table></div></div><input ref="input" style="width: 100px" v-show="false" type="file" /><div class="print-btn" v-if="viewShow"><div class="txt-btn">今日已打印 {{dayCount}} 次 </div><el-button circle type="primary" @click.stop="printAssignFile">打印文件</el-button><el-button circle @click="clearBox">返回上级</el-button></div><div v-show='viewShow' id="viewBox"></div></div>
</template><script>import { printFile, getPrintList } from "@/api/print";import { provePreview, queryPrintsSum } from "@/api/preview";const blobToJson = (data) => {return new Promise((resolve, reject) => {const reader = new FileReader();reader.readAsText(new Blob([data], {type: 'application/json'}), 'utf-8');reader.onload = () => {try {const json = JSON.parse(reader.result);resolve(json);} catch (e) {reject(e);}};});}export default {data() {return {tableData: [],dayCount: '',viewShow: false,dataFile: {},proveId: '',};},mounted(){//获取列表数据this.init();//获取打印次数this.getPrintsSum()},methods: {//获取列表数据init() {getPrintList(this.page).then((res) => {if (res && res.code === 200) {this.tableData = res.data.recordList;} else {this.$message.error(res.msg);}});},//获取打印次数getPrintsSum(){queryPrintsSum().then((res)=>{if(res && res.code == 200){this.dayCount = res.data} else {this.$message.error(res.msg);}})},// 清除pdfclearBox() {this.viewShow = falsevar e = document.querySelector("#viewBox");var child = e.lastElementChild;while (child) {e.removeChild(child);child = e.lastElementChild;}},// 展示PDF文件的预览showPdfPreview(data) {let _self = thisconst deal = () => {try {_self.clearBox()const viewBox = document.getElementById('viewBox');const pdf = document.createElement('iframe')pdf.id = 'iframe'pdf.setAttribute('frameborder', 0)const blob = new Blob([data], {type: 'application/pdf'});const pdfUrl = URL.createObjectURL(blob);pdf.src = pdfUrl + '#toolbar=0';pdf.style.width = '100%'pdf.style.height = '100%'viewBox.appendChild(pdf)_self.viewShow = true} catch (e) {_self.$message.error("未能正确加载文件");_self.clearBox()}}//1. 先将数据转换成json,看下是否是异常try {blobToJson(data).then((json) => {_self.$message.error(json.msg || "未能正确加载文件");_self.clearBox()}).catch((e) => {deal()})} catch (e) {_self.$message.error("未能正确加载文件");_self.clearBox()}},//预览onChangeView(row) {this.dataFile = rowprovePreview({proveId: row.proveId}).then((res) => {this.showPdfPreview(res)//获取打印次数this.getPrintsSum()if (res.code == 500) {this.$message.error("文件加载异常" || res.msg);}}).catch(err => {this.clearBox()this.$message.error("未能正确加载文件");});},//文件打印printAssignFile() {printFile(this.dataFile).then((res) => {if (res.code === 200) {//获取打印次数this.getPrintsSum()this.$message.success(res.msg);} else {this.$message.warning(res.msg);}});},},};
</script>
<style lang='less' scoped>.print {width: 100%;height: 100%;margin-top: 200px;}#viewBox {width: 70%;height: 720px;background-color: #ccc;margin: 0 auto;}.print-btn {position: fixed;top: 180px;right: 60px;display: flex;flex-direction: column;align-items: center;.txt-btn {margin-bottom: 30px;display: block;font-size: 22px;font-weight: 500;color: black;width: 180px;text-align: center;}.el-button {width: 160px;height: 160px;font-size: 22px;}.el-button+.el-button {margin-top: 30px;margin-left: 0 !important;}}
</style>

 预览接口preview.js

/*** 证明预览* @param {*} data pdf文件流* @returns*/
export function provePreview(data) {return request({url: "/layout/api/view",method: "post",data: data,responseType: 'blob',	//一定要设置响应类型,否则页面会是空白pdfcontentType: "application/json;charset=UTF-8"});
}

实现步骤说明

这段代码我定义了一个 blobToJson 的函数,主要是将 Blob 类型的数据转化为 JSON 对象

 🏳‍🌈 实现步骤如下:

  1. 创建一个 Promise 对象,用于异步处理数据转换
  2. 再创建一个 FileReader 对象,用于读取 Blob 类型的数据
  3. 通过 FileReader 对象的 readAsText() 方法,将 Blob 数据以文本形式读取出来,并指定编码格式为 UTF-8
  4. 在 FileReader 对象的 onload 方法中,通过 try...catch 将读取到的文本数据解析成 JSON 对象,并将解析后的结果作为 Promise 的 resolve 返回值。若是解析失败,则将错误信息作为 reject 返回值。
  5. 若是出现了异常,可使用 Promise 的 catch 方法进行捕获和处理。

clearBox() 方法 

clearBox() 方法:在关闭文件预览时,清空预览区域的内容,以便下次预览文件时重新加载新的内容。

 🏳‍🌈 实现步骤如下:

  1. 将 viewShow 设置为 false,即隐藏文件预览区域。
  2. 通过 document.querySelector("#viewBox") 获取到文件预览区域的 DOM 元素。
  3. 使用 while 循环,在文件预览区域内移除所有子元素,直到没有子元素为止。

  showPdfPreview()方法

        showPdfPreview()方法:用于展示PDF文件的预览,并对异常情况进行处理

        在展示预览之前,先将数据转换成json格式,如果转换过程中出现异常,则显示错误消息并清空文件预览区域;如果转换成功,则进行具体的展示逻辑。

 🏳‍🌈 实现步骤如下:

  1. 创建一个deal函数,用于处理展示PDF预览的具体逻辑。
  2. 在deal函数中,首先调用clearBox方法清空文件预览区域的内容。
  3. 将传入的code赋值给组件的code属性,用于在展示预览时进行标识。
  4. 调用queryCount方法查询打印次数。
  5. 创建一个iframe元素,并设置id为'iframe',设置frameborder为0。
  6. 使用Blob对象将传入的data转换为Blob类型,并设置type为'application/pdf'
  7. 通过URL.createObjectURL方法生成PDF文件的URL。
  8. 将生成的PDF URL赋值给iframe的src属性,添加到文件预览区域,并设置宽度和高度为100%。
  9. 将iframe添加到文件预览区域中。
  10. 将组件的viewShow属性设置为true,显示文件预览区域。
  11. 使用try-catch-finally语句对异常进行处理。
  12. 在try块中,首先将data转换为json格式,判断是否存在异常。若有异常,显示错误消息并调用clearBox方法清空文件预览区域。
  13. 在catch块中,捕获到异常时,显示错误消息并调用clearBox方法清空文件预览区域。
  14. 在finally块中,关闭加载状态。

XX证明列表展示 

XX证明文件预览效果图 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/218155.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

lv12 linux内核的安装与加载

目录 1 tftp加载Linux内核及rootfs 1.1 uboot内核启动命令 1.2 uboot自启动参数环境变量 1.3 实验 2 EMMC加载Linux 内核及rootfs ​编辑 2.1 emmc中写入uimage ​编辑 2.2 emmc中写入dtb 2.3 emmc中写入根文件系统 2.4 设置环境变量 3 tftp加载Linux内核nfs挂载ro…

Echarts 热力图与折线图的结合

热力图与折线图结合使用(文末含源码) 这种需求并不多见&#xff0c;遇到后第一时间翻看了Echars官方文档&#xff0c;并没有发现类似的例子。于是自己动手合并了双轴&#xff0c;后发现折线图会被遮盖。经过排查发现了一个关键参数&#xff1a;visualMap的配置。这个配置在热力…

C# 雪花算法生成Id工具类

写在前面 传说自然界中并不存在两片完全一样的雪花的&#xff0c;每一片雪花都拥有自己漂亮独特的形状、独一无二&#xff1b;雪花算法也表示生成的ID如雪花般独一无二&#xff0c;该算法源自Twitter。 雪花算法主要用于解决分布式系统的唯一Id生成问题&#xff0c;在生产环境…

IDEA新建jdk8 spring boot项目

今天新建spring boot项目发现JDK版本最低可选17。 但是目前用的最多的还是JDK8啊。 解决办法 Server URL中设置&#xff1a; https://start.aliyun.com/设置完成后&#xff0c;又可以愉快的用jdk8创建项目了。 参考 https://blog.csdn.net/imbzz/article/details/13469117…

Pytorch从零开始实战13

Pytorch从零开始实战——ResNet与DenseNet探索 本系列来源于365天深度学习训练营 原作者K同学 文章目录 Pytorch从零开始实战——ResNet与DenseNet探索环境准备数据集模型选择开始训练可视化总结 环境准备 本文基于Jupyter notebook&#xff0c;使用Python3.8&#xff0c;P…

【学习笔记】JavaScript中的GC算法

1、内存管理 内存&#xff1a;由可读写单元组成&#xff0c;标识一片可操作的空间 管理&#xff1a; 认为的去操作一篇空间的申请、使用和释放 内存管理&#xff1a;开发者主动申请空间、使用空间、释放空间 管理流程&#xff1a; 申请-使用-释放 // 申请 let obj {} //使…

蓝牙物联网智慧工厂解决方案

蓝牙物联网智慧工厂解决方案是一种针对工厂管理的智能化解决方案&#xff0c;通过蓝牙、物联网、大数据、人工智能等技术&#xff0c;实现工厂人员的定位、物资的定位管理、车间的智慧巡检、智慧安防以及数据的可视化等功能。 蓝牙物联网智慧工厂解决方案构成&#xff1a; 人员…

华为数通——企业双出口冗余

目标&#xff1a;默认数据全部经过移动上网&#xff0c;联通低带宽。 R1 [ ]ip route-static 0.0.0.0 24 12.1.1.2 目的地址 掩码 下一条 [ ]ip route-static 0.0.0.0 24 13.1.1.3 preference 65 目的地址 掩码 下一条 设置优先级为65 R…

Axios入门案例——后端学习

目录 后端准备 导入依赖 解决跨域 User实体类 DemoController测试接口 前端准备 项目结构 axios.js axios.html 开始测试 后端结果 前端结果 后端准备 导入依赖 案例会用到以下的三个依赖。 <dependency><groupId>org.springframework.boot</gro…

基于以太坊的智能合约开发Solidity(事件日志篇)

//声明版本号&#xff08;程序中的版本号要和编译器版本号一致&#xff09; pragma solidity ^0.5.17; //合约 contract EventTest {//状态变量uint public Variable;//构造函数constructor() public{Variable 100;}event ValueChanged(uint newValue); //事件声明event Log(…

Python 自动化之收发邮件(二)

发邮件之Windows进程监控 文章目录 发邮件之Windows进程监控前言一、基本内容二、基本结构三、库模块四、函数模块1.进程监控2.邮件发送 五、程序运行模块1.获取时间2.用户输入3.进程监控3.1进程启动发邮件3.2进程停止发邮件 总结 前言 上一篇简单写了一下如何进行邮件的收发操…

智能优化算法应用:基于黏菌算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于黏菌算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于黏菌算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.黏菌算法4.实验参数设定5.算法结果6.参考文献7.MA…

云原生之深入解析Kubernetes本地持久化存储方案OpenEBS LocalPV的最佳实践

一、K8s 本地存储 K8s 支持多达 20 种类型的持久化存储&#xff0c;如常见的 CephFS 、Glusterfs 等&#xff0c;不过这些大都是分布式存储&#xff0c;随着社区的发展&#xff0c;越来越多的用户期望将 K8s 集群中工作节点上挂载的数据盘利用起来&#xff0c;于是就有了 loca…

PostgreSQL向量数据插件--pgvector安装(附PostgreSQL安装)

PostgreSQL向量数据插件--pgvector安装 一、版本二、数据库安装1. 在官网下载PostgreSQL14.0的安装包2.增加用户postgres3.解压安装 三、pgvector安装1. 从github上克隆下来2. 安装pgvector插件3. 开始使用pgvector启用pgsql命令行创建扩展 本文为本人在安装pgvector中踩过的坑…

自动驾驶学习笔记(十八)——Lidar感知

#Apollo开发者# 学习课程的传送门如下&#xff0c;当您也准备学习自动驾驶时&#xff0c;可以和我一同前往&#xff1a; 《自动驾驶新人之旅》免费课程—> 传送门 《Apollo 社区开发者圆桌会》免费报名—>传送门 文章目录 前言 Lidar感知 运动补偿 点云分割 总结…

MySQL——表的约束

目录 一.表的约束 二.空属性 ​编辑三.默认值 四.列描述 五.主键 1.主键 2.符合主键 六.自增长 七.唯一键 八.外键 一.表的约束 真正约束字段的是数据类型&#xff0c;但是数据类型约束很单一&#xff0c;需要有一些额外的约束&#xff0c;更好的保证数据的合法性&…

26种主流的神经网络偏微分方程求解方法汇总

偏微分方程&#xff08;PDE&#xff09;是数学中一门重要的分支&#xff0c;应用范围广泛涉及自然科学、工程技术、生物学领域等。然而我们都知道&#xff0c;偏微分方程的求解过程异常艰难&#xff0c;如果碰上了特别复杂的&#xff0c;传统的计算方法可能需要数百万个CPU小时…

一些好用的VSCode扩展

可以在扩展这里直接搜索需要的扩展&#xff0c;点击安装即可。 1.Chinese 中文扩展&#xff0c;就是说虽然咱们懂点英语&#xff0c;但还是中文看着方便 2.Auto Rename Tag 当你重命名一个HTML 标签时&#xff0c;会自动重命名与他配对的HTML 标签 当你选择h4这个标签时&…

Docker及其使用思维导图

Docker的架构 构建分发运行镜像 Client&#xff08;客户端&#xff09;&#xff1a;是Docker的用户端&#xff0c;可以接受用户命令和配置标识&#xff0c;并与Docker daemon通信。Images&#xff08;镜像&#xff09;&#xff1a;是一个只读模板&#xff0c;含创建Docker容器…

DevEco Studio 项目鸿蒙(HarmonyOS)资源引用(自定统和系统)

DevEco Studio 项目鸿蒙&#xff08;HarmonyOS&#xff09;资源引用&#xff08;自定统和系统&#xff09; 一、操作环境 操作系统: Windows 10 专业版 IDE:DevEco Studio 3.1 SDK:HarmonyOS 3.1 二、资源访问 HarmonyOS应用资源分为两类&#xff0c;一类是应用资源&…