vue点击pdf文件直接在浏览器中预览文件

好久没有更新文章了,说说为什么会有这篇文章呢,其实是应某个热线评论的要求出的,不过由于最近很长一段时间没打开csdn现在才看到,所以才会导致到现在才出。

先来看看封装完这个预览方法的使用,主打一个方便使用:

复制代码
id:为文件id
name:为文件名称
ajaxDownLoadFile(id, name)

没错就是这么简单,调用这个函数传入id和name就可以实现

进入正题,我们需要怎么去封装这么个预览pdf的工具呢。

其实我们ajaxDownLoadFile这个方法的功能主要是通过传入id和name然后去实现预览pdf文件,如果不是pdf文件的话,点击后我们应该是有一个下载的功能。

实现我们说的这两个点,主要是下面这两个函数
ajaxDownLoadFile 下载文件
ajaxPrePdf预览文件

复制代码
    // 下载文件
    ajaxDownLoadFile(id: string, name?: string) {
        const strRegex = '(.pdf)$' // 用于验证后缀是否是pdf
        const re = new RegExp(strRegex)
        // 如果文件名存在,同时文件为pdf
        if (name&& re.test(name.toLowerCase())) {
            return ajaxPrePdf(id)
        } else {
        //不为pdf的文件,直接请求接口下载文件
            return new Promise((resolve, reject) => {
                service.get({
                    url: XXX + id,
                    responseType: 'blob'
                }).then(res => {
                    resolve(res)
                }).catch(err => reject(err))

            })
        }

    },
    // 预览文件
    ajaxPrePdf(id: string) {
        return new Promise((resolve, reject) => {
            service.get({
                url: XXX + id,
                responseType: 'arraybuffer'
            }).then(res => {
                const file = new Blob([res as any], {type: 'application/pdf'})
                const fileUrl = window.URL.createObjectURL(file)
                window.open(fileUrl)
                resolve(res)
            }).catch(err => reject(err))

        })
    }

所以其实真正实现预览文件的功能的其实就是ajaxPrePdf这个函数。

我们通过封装的方式,让这个方法可以在我们整个项目中使用,甚至其他项目需要到pdf预览其他文件下载的功能,我们也可以直接拿过去用。主打一个简单实用。

相关推荐
humors2212 小时前
pdf工具分享
pdf·工具·程序·网站·转换·处理
子兮曰3 小时前
OpenClaw架构揭秘:178k stars的个人AI助手如何用Gateway模式统一控制12+通讯频道
前端·javascript·github
Howrun7773 小时前
VSCode烦人的远程交互UI讲解
ide·vue.js·vscode
百锦再3 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
百锦再3 小时前
React编程高级主题:测试代码
android·前端·javascript·react.js·前端框架·reactjs
颜酱5 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
小迷糊的学习记录5 小时前
Vuex 与 pinia
前端·javascript·vue.js
发现一只大呆瓜6 小时前
前端性能优化:图片懒加载的三种手写方案
前端·javascript·面试
不爱吃糖的程序媛6 小时前
Flutter 与 OpenHarmony 通信:Flutter Channel 使用指南
前端·javascript·flutter
利刃大大6 小时前
【Vue】Element-Plus快速入门 && Form && Card && Table && Tree && Dialog && Menu
前端·javascript·vue.js·element-plus