vue中预览pdf的方法

使用vue-pdf

备注:这里只介绍了一页的pdf

js 复制代码
<div class="animation-box-pdf">
   <pdf :src="'http://xxxx'" />
</div>

import Pdf from 'vue-pdf'
// src可以是文件地址url,也可以是文件流blob(将blob转成url)
// let url = window.URL.createObjectURL(blob);

使用这种方式的缺点,src的地址切换,文档可以不会刷新为最新的内容,解决方法是在每次预览前清空url地址

pdf带有电子签章的,就是红章,预览不会生效

解决预览签章的问题

使用vue-pdf-signature

这个插件是基于vue-pdf修改的能预览电子签章的

js 复制代码
<div class="animation-box-pdf">
   <pdf :src="'http://xxxx'" />
</div>

import Pdf from 'vue-pdf-signature'

自己去github上克隆vue-pdf的源码,注释掉不允许显示签章的代码,然后打包发布到自己的npm上去,然后安装自己的npm包

自己去把pdfjs-dist包拉下来,改代码打包,把打包后的内容放到项目目录下,引用这个地址

使用iframe

js 复制代码
<iframe :src="http://xxx/xxx.pdf`" style="width: 100%;height: 100%;" frameborder="0"></iframe>

iframe预览会使用浏览器自带的预览窗口,如果不需要工具栏的话,可以在src地址后面添加#toolbar=0

如果想要让pdf占满整个容器宽度,需要设置#view-FitH,top,自适应页面大小。

跳往特定页数page=2

设置默认缩放比例,地址栏后添加#zoom=200

默认侧边栏工具栏处于关闭状态navpanes=0

js 复制代码
<iframe :src="http://xxx/xxx.pdf#toolbar=0&#view-FitH,to`" style="width: 100%;height: 100%;" frameborder="0"></iframe>

使用pdfjs+ iframe


pdfjs-2.6.347-es5-dist

pdfjs的包放在public目录下

js 复制代码
<iframe :src="`/pdfjs-2.6.347-es5-dist/web/viewer.html?file=http://xxx/xxx.pdf`" style="width: 100%;height: 100%;" frameborder="0"></iframe>

使用embed

js 复制代码
<embed :src="`http://xxx/xx.pdf`" width="100%" height="100%" type="application/pdf">
相关推荐
copyer_xyf19 小时前
FastAPI 项目骨架搭建
前端·后端·python
智码看视界19 小时前
老梁聊全栈:CSS3 高级特性—Flex/Grid 布局体系深度解析
前端·css3·布局·flexbox·grid·工程实践·全栈工程师
IT_陈寒19 小时前
Python虚拟环境的这个坑,我居然绕了三天才爬出来
前端·人工智能·后端
星栈独行19 小时前
写 Makepad Demo 不难,难的是把它写成项目
前端·程序人生·ui·rust
深圳恒讯19 小时前
非洲服务器延迟高吗?实测数据与场景化解读
运维·服务器·前端
北极星日淘19 小时前
可买免税店货物与安耐晒——特殊商品代购技术方案
javascript·vue.js·elementui
终将老去的穷苦程序员19 小时前
npm : 无法加载文件 C:\Program Files\nodejs\npm.ps1,因为在此系统上禁止运行脚
前端·npm·node.js
之歆19 小时前
Day10_Node.js 与 Express 开发实战指南:从零到一构建专业级 Web 服务
前端·node.js·express
问心无愧051320 小时前
ctf show web入门107
android·前端·笔记·android studio