【前端】小程序实现预览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'
				})
			}
		})
	})
}
相关推荐
heytoo几秒前
同一个模型,为什么结果差10倍?差的不是模型
前端·agent
霪霖笙箫1 分钟前
「JS全栈AI学习」九、Multi-Agent 系统设计:架构与编排
前端·面试·全栈
慕斯fuafua3 分钟前
CSS——定位
前端·css
Cache技术分享3 分钟前
384. Java IO API - Java 文件复制工具:Copy 示例完整解析
前端·后端
嵌入式小企鹅4 分钟前
国芯抗量子MCU突破、太空算力元年开启、AI编程工具密集发布
学习·ai·边缘计算·算力·risc-v·芯片·半导体
shadowcz0075 分钟前
Chrome Skills 来了:把你的 AI 提示词变成一键工具
前端·人工智能·chrome
踩着两条虫5 分钟前
VTJ核心引擎开源项目概览
前端·vue.js·低代码
Front思6 分钟前
解决 uniapp Dart Sass 2.0.0 弃用警告
前端·uni-app·sass
农夫山泉不太甜6 分钟前
CSS 新特性与冷门属性深度剖析
前端
Hy行者勇哥8 分钟前
Chrome 浏览器如何“网页长截图”和“网站打包成应用”
前端·chrome