位置: IT常识 - 正文

接收后端返回的pdf文件流 前端使用Vue-pdf实现预览(分页)(后端接口返回数据类型规范)

编辑:rootadmin
接收后端返回的pdf文件流 前端使用Vue-pdf实现预览(分页) vue系列文章目录

推荐整理分享接收后端返回的pdf文件流 前端使用Vue-pdf实现预览(分页)(后端接口返回数据类型规范),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:后端返回数据格式有哪些,前端接收后端返回值,后端接口返回数据类型规范,后端接收对象,后端返回数据格式有哪些,前端接收后端返回值,后端接口返回数据类型规范,前端接收后端返回值,内容如对您有帮助,希望把文章链接给更多的朋友!

需求:后端返回文件流前端将文件流转为成blob地址预览pdf文件

提示:以下是本篇文章正文内容,下面案例可供参考

一、安装PDF插件依赖

npm install vue-pdf --save

二、封装vuePdf组件为预览页面,通过Management.vue路由传参形式跳转到预览页面1.Management.vue

代码如下(示例):

封装的请求pdfDocument 一定要加上 { responseType: "blob", }

后台返回的pdf文件流 也就是result.data 附代码:

// 预览 async scanSubmit(row) { // 这个代码我不多做解释,接口请求而已 const result = await pdfDocument(this.fileId); // 直接使用createObjectURL可能会出现问题 // 所以我建议使用下面这种方式将文件流转化为本地blod地址 var binaryData = []; binaryData.push(result.data); console.log(binaryData); // 记得一定要设置application的类型 let url = window.URL.createObjectURL( new Blob(binaryData, { type: "application/pdf;charset=utf-8", }) ); if (url != null && url != undefined && url) { // vue路由跳转并以问号形式携带vue-pdf预览时所需要的pdf地址 const { href } = this.$router.resolve({ path: "/vuePdf", query: { //要传的参数 url: url, }, }); // 新页面打开 window.open(href, "_blank"); this.openTheScanningdialog = false; } },2.vuedf.vue接收后端返回的pdf文件流 前端使用Vue-pdf实现预览(分页)(后端接口返回数据类型规范)

HTML部分,无需修改,复制可直接使用

<template> <div id="container"> <!-- 上一页、下一页 --> <div class="right-btn"> <!-- 输入页码 --> <div class="pageNum"> <input v-model.number="currentPage" type="number" class="inputNumber" @input="inputEvent()" /> / {{ pageCount }} </div> <div @click="changePdfPage('first')" class="turn">首页</div> <!-- 在按钮不符合条件时禁用 --> <div @click="changePdfPage('pre')" class="turn-btn" :style="currentPage === 1 ? 'cursor: not-allowed;' : ''" > 上一页 </div> <div @click="changePdfPage('next')" class="turn-btn" :style="currentPage === pageCount ? 'cursor: not-allowed;' : ''" > 下一页 </div> <div @click="changePdfPage('last')" class="turn">尾页</div> </div> <div class="pdfArea"> <!-- // 不要改动这里的方法和属性,下次用到复制就直接可以用 --> <pdf :src="src" ref="pdf" v-show="loadedRatio === 1" :page="currentPage" @num-pages="pageCount = $event" @progress="loadedRatio = $event" @page-loaded="currentPage = $event" @loaded="loadPdfHandler" @link-clicked="currentPage = $event" style="display: inline-block; width: 100%" id="pdfID" ></pdf> </div> <!-- 加载未完成时,展示进度条组件并计算进度 --> <div class="progress" v-if="loadedRatio != 1"> <el-progress type="circle" :width="70" color="#53a7ff" :percentage=" Math.floor(loadedRatio * 100) ? Math.floor(loadedRatio * 100) : 0 " ></el-progress> <br /> <!-- 加载提示语 --> <span>{{ remindShow }}</span> </div> </div></template>

JS部分,无需修改,复制可直接使用

<script>import pdf from "vue-pdf";export default { components: { pdf, }, data() { return { // ----- loading ----- remindText: { loading: "加载文件中,文件较大请耐心等待...", refresh: "若卡住不动,可刷新页面重新加载...", }, remindShow: "加载文件中,文件较大请耐心等待...", intervalID: "", // ----- vuepdf ----- // src静态路径: /static/xxx.pdf // src服务器路径: 'http://.../xxx.pdf' src: "", // 当前页数 currentPage: 0, // 总页数 pageCount: 0, // 加载进度 loadedRatio: 0, }; }, created() { // 页面加载,拿到路由中的url复制给data中的src this.src = this.$route.query.url; console.log(this.src); }, mounted() { // // 更改 loading 文字 this.intervalID = setInterval(() => { this.remindShow === this.remindText.refresh ? (this.remindShow = this.remindText.loading) : (this.remindShow = this.remindText.refresh); }, 4000); }, methods: { // 页面回到顶部 toTop() { document.getElementById("container").scrollTop = 0; }, // 输入页码时校验 inputEvent() { if (this.currentPage > this.pageCount) { // 1. 大于max this.currentPage = this.pageCount; } else if (this.currentPage < 1) { // 2. 小于min this.currentPage = 1; } }, // 切换页数 changePdfPage(val) { if (val === "pre" && this.currentPage > 1) { // 切换后页面回到顶部 this.currentPage--; this.toTop(); } else if (val === "next" && this.currentPage < this.pageCount) { this.currentPage++; this.toTop(); } else if (val === "first") { this.currentPage = 1; this.toTop(); } else if (val === "last" && this.currentPage < this.pageCount) { this.currentPage = this.pageCount; this.toTop(); } }, // pdf加载时 loadPdfHandler(e) { // 加载的时候先加载第一页 this.currentPage = 1; }, }, destroyed() { // 在页面销毁时记得清空 setInterval clearInterval(this.intervalID); },};</script>

CSS部分,可根据自己的需求自行修改

<style scoped>#container { position: absolute !important; left: 0; right: 0; bottom: 0; top: 0; background: #f4f7fd; overflow: auto; font-family: PingFang SC; width: 100%; display: flex; /* justify-content: center; */ position: relative;}/* 右侧功能按钮区 */.right-btn { position: fixed; right: 5%; bottom: 15%; width: 120px; display: flex; flex-wrap: wrap; justify-content: center; z-index: 99;}.pdfArea { width: 900px; margin: 0 auto;}/* ------------------- 输入页码 ------------------- */.pageNum { margin: 10px 0; font-size: 18px;}/*在谷歌下移除input[number]的上下箭头*/input::-webkit-outer-spin-button,input::-webkit-inner-spin-button { -webkit-appearance: none !important; margin: 0;}/*在firefox下移除input[number]的上下箭头*/input[type="number"] { -moz-appearance: textfield;}.inputNumber { border-radius: 8px; border: 1px solid #999999; height: 35px; font-size: 18px; width: 60px; text-align: center;}.inputNumber:focus { border: 1px solid #00aeff; background-color: rgba(18, 163, 230, 0.096); outline: none; transition: 0.2s;}/* ------------------- 切换页码 ------------------- */.turn { background-color: #164fcc; opacity: 0.9; color: #ffffff; height: 70px; width: 70px; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 5px 0;}.turn-btn { background-color: #164fcc; opacity: 0.9; color: #ffffff; height: 70px; width: 70px; border-radius: 50%; margin: 5px 0; display: flex; align-items: center; justify-content: center;}.turn-btn:hover,.turn:hover { transition: 0.3s; opacity: 0.5; cursor: pointer;}/* ------------------- 进度条 ------------------- */.progress { position: absolute; right: 50%; top: 50%; text-align: center;}.progress > span { color: #199edb; font-size: 14px;}</style>效果图

**

实现下载/在线打开

**

①安装downloadjs

npm install downloadjs

②在需要的地方引入

import download from 'downloadjs'

③在下载的方法里调用download就可以实现下载了

文件流数据 保存的名字 要下载的文件类型

本文链接地址:https://www.jiuchutong.com/zhishi/283607.html 转载请保留说明!

上一篇:fs20.exe是什么进程 有什么作用 fs20进程查询(电脑fs0是什么)

下一篇:一只躺在沙滩上的港海豹幼崽,德国黑尔戈兰岛 (© Fotofeeling/Westend61/Offset)(一只躺在沙滩上的鸟)

  • 游戏试玩赚钱的方法有哪些?(游戏试玩赚钱的网站)

    游戏试玩赚钱的方法有哪些?(游戏试玩赚钱的网站)

  • 荣耀手表2可以升级鸿蒙吗(荣耀手表2可以戴着洗澡吗)

    荣耀手表2可以升级鸿蒙吗(荣耀手表2可以戴着洗澡吗)

  • 苹果后台应用刷新什么意思

    苹果后台应用刷新什么意思

  • 华为nova6se可以隐藏应用吗(华为nova6se可以用6A充电线吗)

    华为nova6se可以隐藏应用吗(华为nova6se可以用6A充电线吗)

  • 华为畅享10e与荣耀9x对比(华为畅享10e与荣耀play)

    华为畅享10e与荣耀9x对比(华为畅享10e与荣耀play)

  • Excel打印时怎么每页都有标题(excel打印时怎么让隐藏的内容显示出来)

    Excel打印时怎么每页都有标题(excel打印时怎么让隐藏的内容显示出来)

  • 抖音怎么不进直播间看直播(抖音怎么不进直播间退团)

    抖音怎么不进直播间看直播(抖音怎么不进直播间退团)

  • reno3pro充电器多少w(opporeno3pro充电器多少a)

    reno3pro充电器多少w(opporeno3pro充电器多少a)

  • 三星s10气密度多少正常(三星s10e气密度多少正常)

    三星s10气密度多少正常(三星s10e气密度多少正常)

  • qq显示解除关系是被对方删了吗(qq显示解除关系怎么回事)

    qq显示解除关系是被对方删了吗(qq显示解除关系怎么回事)

  • 小米手表丢了能定位吗(小米手表丢了能报警吗)

    小米手表丢了能定位吗(小米手表丢了能报警吗)

  • dc头2.1和2.5如何区分(dc2.1和2.5区别)

    dc头2.1和2.5如何区分(dc2.1和2.5区别)

  • 为什么200m的宽带网速测下来只有100m(为什么200m的宽带网速测下来只有20m)

    为什么200m的宽带网速测下来只有100m(为什么200m的宽带网速测下来只有20m)

  • 微信app一直显示等待中(微信app一直显示网络异常)

    微信app一直显示等待中(微信app一直显示网络异常)

  • 手机过安检会不会照坏(手机过安检不显示)

    手机过安检会不会照坏(手机过安检不显示)

  • 现代电子计算机特点(现代电子计算机诞生的理论基础是)

    现代电子计算机特点(现代电子计算机诞生的理论基础是)

  • 换手机信息如何转移到另外手机上(换手机之后信息怎么转移)

    换手机信息如何转移到另外手机上(换手机之后信息怎么转移)

  • 华为9x有面部识别吗(华为9x面部识别)

    华为9x有面部识别吗(华为9x面部识别)

  • 美团接单必须要打印机吗(美团骑手一定要接单吗)

    美团接单必须要打印机吗(美团骑手一定要接单吗)

  • vivo深色模式省电吗(vivo深色模式省电还是费电)

    vivo深色模式省电吗(vivo深色模式省电还是费电)

  • 三星a8svoice怎么关闭(三星svoice怎么用)

    三星a8svoice怎么关闭(三星svoice怎么用)

  • 发送朋友验证对方能看到吗(发送朋友验证对方能收到吗)

    发送朋友验证对方能看到吗(发送朋友验证对方能收到吗)

  • 美图mp1709是什么型号(美图mp1709是什么手机)

    美图mp1709是什么型号(美图mp1709是什么手机)

  • 面对面建群有效时间(什么是面对面建微信群)

    面对面建群有效时间(什么是面对面建微信群)

  • 【深度学习】详解 MoCo

    【深度学习】详解 MoCo

  • 税务检查的定义
  • 律师事务所的所训
  • 全年一次性奖金个税计算
  • 卷式发票是什么样的
  • 实发工资知道如何发放吗
  • 减免税金需要计提吗
  • 劳保如何入账
  • 公司简易注销需要清算吗
  • 土地增值税清算利息扣除规定
  • 营改增后无形资产的出租和出售都属于增值税纳税范围
  • 仓储费和仓储服务费的区别
  • 收到银行承兑会计分录
  • 税率和征收率的含义和区别
  • 第三方付款会计分录
  • 土地款抵扣增值税申报
  • 限售股所得税的优惠政策
  • 矿泉水售卖方式
  • 建筑行业小规模企业所得税税率
  • 材料卸车费可计入人工费吗
  • 增值税申报错误怎么处理
  • 办理转移登记需要什么资料
  • 华为鸿蒙系统怎么降级版本
  • 激活windows11怎么激活
  • 超标的业务招待费属于什么差异
  • 计提待摊费用怎么记账
  • php curl模块
  • PHP:Memcached::setMultiByKey()的用法_Memcached类
  • msmpeng.exe 是什么
  • 核定企业应税收怎么算
  • 广告公司的材料的作用有哪些
  • hpptd.exe
  • 什么是主营业务税金及附加
  • 矿产资源补偿费计入科目
  • 高新技术企业股权转让
  • 最小的外置dvd刻机多少寸
  • php rsa
  • 新所得税会计准则
  • 公司支付工伤赔偿,是先签字还是先打钱
  • antd form table
  • css点击菜单显示内容
  • 03-JavaScript基础
  • 事业单位用其他资金用于还单位贷款违法吗
  • 普票专票的销售额怎么理解
  • 不能加计扣除的研发费用在辅助账怎么反映
  • 劳务外经证预缴税款
  • 房屋租赁如何入账
  • 个体工商户免费开票额度
  • sql2008用ip连接不了
  • 商铺固定设施指哪些
  • 进口关税减免政策
  • 网络服务费计入什么费用
  • 营改增有什么好处
  • 递延所得税会计处理全过程
  • 支付平台费率
  • 民办非企业单位什么意思
  • 如何处理公益性岗位问题
  • 公司注销其他应收款余额要交税吗
  • 费用报销单怎么写 样本图片
  • 汇算清缴要补交0.01怎么调成0
  • centos6.5中文
  • 使用dhcp的好处有哪些
  • fedora使用
  • hpz12进程
  • mac自带计算器
  • win10 开始
  • wire软件下载
  • Unity Socket TCP
  • opengl glbegin
  • ftp下载工具能自动登录ftp服务器
  • web开发css
  • django settings.py
  • 使用chrome浏览器打开
  • js原型作用
  • javascript闭包运行原理
  • 12366纳税服务热线存在的问题
  • 发票单位可以开一批吗?
  • 煤炭开什么发票
  • 微信密码忘记了,手机号也没有用了,怎么办
  • 国税开票系统怎么增行
  • 消费税税目税率表2019
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设