位置: IT常识 - 正文

vue通过url方式展示PDF方法总结(vue通过url访问单个页面)

编辑:rootadmin
vue通过url方式展示PDF方法总结

推荐整理分享vue通过url方式展示PDF方法总结(vue通过url访问单个页面),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue如何访问外部url,vue通过url访问单个页面,vue_app_url,vue中url存在的两种方式,vue url-loader,vue url,vue url,vue url-loader,内容如对您有帮助,希望把文章链接给更多的朋友!

最近vue项目中遇到预览pdf出现乱码问题,尝试了各种办法受尽折磨,以此记录一下使用的几种方法

1.使用pdfjs-dist 插件,通过iframe标签显示 

首先 npm install pdfjs-dist --save

 npm直接下载插件  npm install --save pdfjs-dist@2.0.943,@2.0.943这是指定版本号,不需要指定版本的就不需要带,下载后在使用的页面直接引入。

 然后直接设置pdf路径就可以直接展示,downloadUrl 是插件中的viewer.html地址,resFile是文件下载地址,到此就能正常预览PDF,组件功能也很多,如需要额外的功能也可以在viewer.js自行修改

vue通过url方式展示PDF方法总结(vue通过url访问单个页面)

 2.使用vue-pdf插件

        执行下面命令下载插件(vue-pdf是基于pdfjs-dist),并修改pacakge.json文件 

        npm i pdfjs-dist@2.5.207 --save        npm i vue-pdf@4.2.0 --save

        "dependencies": {                   "pdfjs-dist": "2.5.207",                   "vue-pdf": "4.2.0",           }

        在使用的页面中直接引入插件,标签为<pdf>就可以,路径赋值同第一种方法

 3.第三种方法使用了pdfjs-dist插件,通过url实现PDF转图片显示

引入需要的插件pdfjs-dist,workerSrc(具体功能可以百度,没搞明白)

 本地文件URL:

 通过URL转换blob类型,然后转为base64,这块可以直接拿去用,getDay()方法可以换成自己想要的文件名,这个方法转成base64后是包含前面类型的,又处理了一下,看个人需求

fileLinkToStreamDownload(url) { let fileName = this.getDay() let reg = /^([hH][tT]{2}[pP]:\/\/|[hH][tT]{2}[pP][sS]:\/\/)(([A-Za-z0-9-~]+).)+([A-Za-z0-9-~\/])+$/ if (!reg.test(url)) { throw new Error('传入参数不合法,不是标准的文件链接') } else { let xhr = new XMLHttpRequest() xhr.open('get', url, true) xhr.setRequestHeader('Content-Type', `application/pdf;charset-UTF-8`) xhr.responseType = 'blob' let that =this xhr.onload = function() { if (this.status == 200) { //接受二进制文件流 var blob = this.response // that.downloadExportFile(blob, fileName); that.blobToBase64(blob).then(res => { // blob转base64 let baseArr = res.split(','); that.showPdf(baseArr[1]); }) } } xhr.send() } }, //Blob类型转BASE64 blobToBase64(blob) { return new Promise((resolve, reject) => { const fileReader = new FileReader(); fileReader.onload = (e) => { resolve(e.target.result); }; // readAsDataURL fileReader.readAsDataURL(blob); fileReader.onerror = () => { reject(new Error('blobToBase64 error')); }; }); }, getDay() { let time = new Date(), year = time.getFullYear(), month = time.getMonth() + 1, day = time.getDate(), timeStem = time.getTime() return `${year}/${month}/${day}/${timeStem}.pdf` },

拿到base64后,开始转图片处理:这个原理这里不多说了,也是照搬的, 如果PDFJS.getDocument()获取不到pdf对象,可以考虑一下版本问题(@2.2.228亲测好用)

async showPdf(base64Val) { let pdfList = document.querySelector('.pdfList') //通过querySelector选择DOM节点,使用document.getElementById()也一样 let base64 = base64Val //获得bas464编码 let decodedBase64 = window.atob(base64) //使用浏览器自带的方法解码 let pdfCurrent = await PDFJS.getDocument({data: decodedBase64}) //返回一个pdf对象 let pages = pdfCurrent.numPages //
本文链接地址:https://www.jiuchutong.com/zhishi/296160.html 转载请保留说明!

上一篇:Vue3 项目中使用setup()函数报错,script setup cannot contain ES module exports(vue3使用教程)

下一篇:VScode常用快捷键、(vscodehtml快捷键)

  • 企业办理纳税手续需要带什么材料
  • 以前年度损益调整
  • 生产设备保险费会计分录
  • 留存收益的个别资本成本率计算公式
  • 勘探费收费标准
  • 零余额账户出纳做什么
  • 执行企业会计准则第21号租赁的企业
  • 月销售额不超过10万
  • 电子发票冲红还是作废
  • 物业公司可以开租赁发票吗
  • 非破产清算会计案例
  • 丢失发票已报税证明单取消
  • 无形资产出租后还要摊销吗
  • 营改增后房地产企业如何开票
  • 发行股票所支付的手续费计入
  • 其他非流动负债包括哪些科目
  • 开具增值税专用发票证明
  • 小规模专票冲红怎么操作
  • 计提个人生产经营所得个税需要贴附件吗
  • 对公账户钱怎么退回去
  • 残保金所属期与税款所属期
  • 发票密码区出格了怎么调整
  • 子公司评估增值 出售股权
  • 利润表没有其他业务利润
  • 月不超过10万,季不超过30万免什么税
  • 自建厂房领用材料进项税的处理
  • 坏账收回的会计处理方法
  • 长期待摊费用的计算公式
  • 销售自己使用过的物品的税率
  • linux系统情况
  • 结转工程成本属于什么会计科目
  • thinkphp limit
  • 企业所得税税前扣除凭证(发票)风险提示反馈
  • php curl_init
  • php 图片上传
  • php中的函数
  • 政府会计制度中固定资产报废的账务处理
  • ant design vue 表单
  • php设置header参数
  • vue在项目中怎么用的
  • 深度学习参数初始化(二)Kaiming初始化 含代码
  • 工业企业采购部工资计入什么科目
  • 缴纳残保金的计税依据是什么
  • 出租房屋收取跨年度的预收租金收入
  • 校验码如何查询
  • python中删除字典里的空项目
  • 以前年度损益调整会计分录
  • 母公司子公司下面的子公司怎么称呼
  • sql server临时表的生命周期
  • 内部审计和外部审计可以相互接触对方的
  • 权益性投资收益确认收入时间
  • 当月未开票收入八百万
  • 个税 退手续费
  • 公司给员工买房子如何做账
  • 飞机票退票费如何开票
  • 收到保险理赔款计入什么科目
  • 行政事业单位基本户核算内容
  • mysql5.7分区表
  • 出现windows boot manager
  • windows锁屏界面设置
  • 7款应用最广泛的游戏
  • 硬盘xp系统
  • linux怎么操作命令
  • 深入理解新发展理念,推进供给侧结构性改革 心得体会
  • jquery验证
  • 用bat脚本快速编程
  • 家字取名男孩名字
  • uleb128、sleb128和uleb128p1编码格式介绍
  • js基础教程
  • jquery获取值的几种方法
  • boost源码编译
  • 安徽省低保查询入口官网
  • 税控盘时间不对有影响吗
  • 郑州地铁客服热线电话
  • 内蒙古国地税联合办税服务厅
  • 绵阳税务局副局长
  • 一般纳税人税务事项告知书在哪里打
  • 新疆税务服务网
  • 什么是财务舞弊行为
  • 全年个人一次性奖金单独计税优惠
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设