当前位置:首页 » 《关于电脑》 » 正文

Vue3前端多种方式超简单预览PDF文件一文搞定(内附源码示例自取)

15 人参与  2024年10月30日 10:02  分类 : 《关于电脑》  评论

点击全文阅读


目录

介绍

安装环境

预览pdf

本地文件预览 

在线路径预览

下载文件路径预览

学习源码


介绍

在前端vue中有时会遇到需要进行预览pdf的场景,前段时间我一位前端朋友就有遇到这个问题,也和我进行了一些探讨

其中预览pdf场景主要会有三种情况:

本地文件,pdf在线预览路径,pdf下载路径三种,其中前面两种还比较常见,但是第三种的pdf下载路径进行预览这种场景还是不是太多的,因为他们后端给返回的路径就是一个下载路径,路径放到浏览器里面会直接进行下载pdf

下面将会以vue3为例来进行预览pdf的演示

安装环境

vue3

第三方包组件

npm install vue-pdf-embed@^1.1.6npm install vue3-pdfjs@^0.1.6

预览pdf

主要组件代码如下

本地文件预览 

首先第一种情况,直接把pdf文件放入项目目录中进行预览

启动查看效果

预览成功

在线路径预览

 比较常见的就是一个可以直接拿来预览的路径,比如下面的路径:

http://static.shanhuxueyuan.com/test.pdf

书写预览代码

 预览成功

当然也可以使用系统自带的iframe进行预览

查看预览效果

 预览样式有些丑需要自己进行书写样式,当然本地文件那种也可以使用iframe进行预览,可以自己尝试下

下载文件路径预览

极少数情况下拿到的是一个直接下载的路径,此时前端不想进行下载想直接对该路径进行预览,当然前面的组件也完全可以兼容这种写法

首先后端准备提供一个下载文件的接口路径

 @GetMapping("/downloadPdf")    public ResponseEntity<StreamingResponseBody> downloadPdf() {        // 指定本地 PDF 文件的路径        String filePath = "C:\\var\\示例2.pdf";        File file = new File(filePath);        // 检查文件是否存在        if (!file.exists()) {            return ResponseEntity.notFound().build();        }        // 设置响应头        HttpHeaders headers = new HttpHeaders();        headers.add(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=test.pdf");        headers.add("Cache-Control", "no-cache, no-store, must-revalidate");        headers.add("Pragma", "no-cache");        headers.add("Expires", "0");        // 返回 StreamingResponseBody        StreamingResponseBody body = outputStream -> {            try (FileInputStream fis = new FileInputStream(file)) {                byte[] buffer = new byte[4096];                int bytesRead;                while ((bytesRead = fis.read(buffer)) != -1) {                    outputStream.write(buffer, 0, bytesRead);                }            } catch (IOException e) {                e.printStackTrace();            }        };        return ResponseEntity.ok()                .headers(headers)                .contentLength(file.length())                .contentType(MediaType.APPLICATION_OCTET_STREAM)                .body(body);    }

服务启动后将接口路径直接放入到浏览器中回车验证是否直接进行文件的下载

下载成功表示该路径就是一个直接下载的路径

 

查看预览效果:

预览成功

但是此时嵌套一般的iframe组件就不行了

查看预览 

预览失败,浏览器直接下载文件了

学习源码

vue3预览pdf示例源码

提取码: nuq6


点击全文阅读


本文链接:http://zhangshiyu.com/post/179836.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 进错房,嫁给八零最牛特种兵已完结(林晚夏江肆年)抖音热文_《进错房,嫁给八零最牛特种兵已完结》最新章节免费在线阅读 -
  • 重生后选魔族,天族哭着求我当王全章节(月沁雪任意)全文免费阅读无弹窗大结局_(重生后选魔族,天族哭着求我当王全章节)重生后选魔族,天族哭着求我当王全章节免费阅读全文最新章节列表_笔趣阁(重生后选魔族,天族哭着求我当王全章节) -
  • 捡回摄政王后,她在皇室作威作福完结版小说(景飞鸢赵灵杰)全文免费阅读无弹窗大结局_(捡回摄政王后,她在皇室作威作福完结版免费阅读全文大结局)最新章节列表_笔趣阁(捡回摄政王后,她在皇室作威作福完结版) -
  • 千金难泣(立轩苏子骞翠竹吴进)全本免费在线阅读_千金难泣最新章节在线阅读(立轩苏子骞翠竹吴进)
  • 《沈云阶傅宴辞》(沈云阶傅宴辞》已完结完整版全集大结局小说)全文阅读笔趣阁
  • 《沈凌峰沈国华》已完结小说全文阅读笔趣阁《沈凌峰沈国华》
  • 《傅嫤韩恬魏郯程茂》已完结(傅嫤韩恬魏郯程茂)热门小说全目录完整版)全文阅读笔趣阁
  • 八零俏军医错嫁糙汉军官:番外+全文+后续(贺昭朗孟翩然)完本小说免费_全本免费小说八零俏军医错嫁糙汉军官:番外+全文+后续最新小说全文阅读(贺昭朗孟翩然)
  • 失去千千万万遍在线阅读(阮相宜陆凛言)全文免费阅读无弹窗大结局_(失去千千万万遍在线阅读)失去千千万万遍在线阅读免费阅读全文最新章节列表_笔趣阁(失去千千万万遍在线阅读) -
  • 脱离世界后,妻子疯了火爆小说小说(沈夕颜林程言)全文免费阅读无弹窗大结局_(脱离世界后,妻子疯了火爆小说免费阅读全文大结局)最新章节列表_笔趣阁(脱离世界后,妻子疯了火爆小说) -
  • 跨年发生踩踏,男友为救白月光丢下我(温林初宝宝)免费阅读 -
  • 都重生了,还不离婚等啥呢宋招弟霍文铮小说在线章节免费阅读

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1