【前端】小程序实现预览pdf并导出

小程序实现预览pdf并导出

一、前言

小程序没办法直接导出pdf或一些文档,只能借助api先将文件下载下来并打开,再让用户手动去保存。之前做"小程序当前页面截图转pdf导出"功能的时候,小程序好像也无法实现。所以要打开文件,都让后端去做吧,要么给前端一个文件地址,要么返回二进制文件流,这样小程序就能打开文件了。

二、需要的wx api

  • downloadFile(下载文件)
  • openDocument(打开文件)
    showMenu设置为true才能支持用户把文件下载到本地

三、完整代码

js 复制代码
const preViewPdf = (url) => { // 预览pdf
	uni.showLoading({
		title: '加载中',
		mask: true
	})

	return new Promise((resolve, reject) => {
		uni.downloadFile({
			url: baseUrl + url,
			header: {
				'Authorization': store.state.token
			},
			success: (res) => {
				if (res.statusCode === 200) {
					uni.openDocument({
						filePath: res.tempFilePath,
						showMenu: true, //显示右上角三个点,支持手动保存到本地
						success: (res) => {
							uni.hideLoading()
							resolve(true)
						},
						fail: (err) => {
							uni.hideLoading()
							resolve(true)
							uni.showToast({
								title: '打开失败',
								icon: 'none'
							})
						}
					})
				}
			},
			fail: (err) => {
				uni.hideLoading()
				uni.showToast({
					title: '下载失败',
					icon: 'none'
				})
			}
		})
	})
}
相关推荐
Xzq2105091 天前
网络基础学习(一)
网络·学习
Fuliy961 天前
第三阶段:进化与群体智能 (Evolutionary & Swarm Intelligence)
人工智能·笔记·python·学习·算法
ejinxian1 天前
Go语言完整学习规划(2026版)- Part 1
学习·go
csdn_aspnet1 天前
Asp.Net Core 10.0 中的 Blazor 增强功能
前端·后端·asp.net·blazor·.net10
小陈phd1 天前
多模态大模型学习笔记(十六)——Transformer 学习之 Decoder Only
人工智能·笔记·深度学习·学习·自然语言处理·transformer
SuperEugene1 天前
Excel 上传解析 + 导出实战:Vue+xlsx 避坑指南|Vue生态精选
前端·javascript·vue.js·excel·xlsx·vxetable
杰建云1671 天前
门店小程序是否有必要做
小程序·小程序搭建
艾莉丝努力练剑1 天前
【QT】常用控件(一):初识控件,熟悉QWidget
android·linux·数据库·qt·学习·mysql·qt5
Greg_Zhong1 天前
小程序中页面和组件的区别
小程序
小马_xiaoen1 天前
常规优化已用尽?小程序体积深层次优化实战!!!
前端·小程序·uniapp