uni-app预览pdf(适配多端)

前言

今天有个功能要在当前页面预览pdf,并且适配多端,研究了好久,也踩了好多坑,写个文章记一下,也给各位避避坑~

uni-app预览pdf

1.下载pdf.js

官方下载地址(有坑!待会儿说)

外部下载地址

2.使用步骤

static 文件夹下新建 pdf 文件夹,将解压文件放进 pdf 文件夹下

(听说这里也有坑:放到根目录下后,无法打开预览的pdf文件)

在当前需要预览的vue页面中,先将文件链接下载为本地文件,代码如下:

js 复制代码
openPdfFn(url) {
    uni.downloadFile({
		//需要预览的文件地址
		url: url,
		success: (res) => {
			if (res.statusCode === 200) {
				//下载成功,得到文件临时地址
				console.log('下载成功', res.tempFilePath);

				//条件编译,若为h5端则直接赋值文件地址			
				// #ifdef H5
				let newUrl = res.tempFilePath
				// #endif

				//条件编译,若为App端,则需要将本地文件系统URL转换为平台绝对路径	
				// #ifdef APP-PLUS
				let newUrl = plus.io.convertLocalFileSystemURL(res.tempFilePath)
				// #endif

				//这里新建一个vue页面,跳转并预览pdf文档
				uni.navigateTo({
					url: "/pages/userInfo/showPdf?url=" + newUrl,
				})
			}
		}
	})
},

这是新建的vue页面,用于web-view预览pdf文件,代码如下:

js 复制代码
<template>
	<view>
		<web-view :src="showUrl"></web-view>
	</view>
</template>

<script>
	export default {
		data() {
			return {
				showUrl: "",
				viewerUrl: '/static/pdf/web/viewer.html', //刚解压的文件地址,用来渲染PDF的html
			}
		},
		onLoad(e) {
			this.showUrl = this.viewerUrl + '?file=' + e.url //将插件地址与接收的文件地址拼接起来
		},
	}
</script>

<style></style>

成功预览

现在讲讲官方地址下载的坑

先说我在官方地址下载的pdf.js报了什么错:Promise.withResolvers is not a function

最终一路排查为版本兼容性问题:原因是新版pdf.js中使用了此方法,但node.js从V22.0.0开始支持此方法

解决方案:

  1. 降低pdf.js版本
  2. 提高node.js版本
相关推荐
计算机-秋大田22 分钟前
基于Spring Boot的兴顺物流管理系统设计与实现(LW+源码+讲解)
java·vue.js·spring boot·后端·spring·课程设计
禾苗种树1 小时前
在 Vue 3 中使用 ECharts 制作多 Y 轴折线图时,若希望 **Y 轴颜色自动匹配折线颜色**且无需手动干预,可以通过以下步骤实现:
前端·vue.js·echarts
小盼江3 小时前
水果生鲜农产品推荐系统 协同过滤余弦函数推荐水果生鲜农产品 Springboot Vue Element-UI前后端分离 代码+开发文档+视频教程
vue.js·spring boot·ui
初遇你时动了情3 小时前
react module.scss 避免全局冲突类似vue中scoped
vue.js·react.js·scss
黑云压城After4 小时前
uniapp小程序自定义日历(签到、补签功能)
小程序·uni-app
烂蜻蜓4 小时前
Uniapp 设计思路全分享
前端·css·vue.js·uni-app·html
Elena_Lucky_baby4 小时前
uniapp封装请求
uni-app
bin91534 小时前
DeepSeek 助力 Vue 开发:打造丝滑的二维码生成(QR Code)
前端·javascript·vue.js·ecmascript·deepseek
尚学教辅学习资料5 小时前
基于SpringBoot+Vue+uniapp的高校招聘小程序+LW参考示例
spring boot·uni-app·招聘系统
岑梓铭7 小时前
uniapp邪门事件
uni-app