uniapp开发小程序,导出文件打开并保存,实现过程downloadFile下载,openDocument打开

uniapp开发小程序,导出文件打开并保存

实现思路

1、调用请求获取到后端接口返回的下载文件的url路径 (注意必须是https的路径,域名需要配置在微信小程序后台的合法域名里面)

2、使用 uni.downloadFile 方法 (下载文件资源到本地,客户端直接发起一个 HTTP GET 请求,返回文件的本地临时路径。)

3、使用 uni.openDocument(OBJECT)方法

新开页面打开文档,支持格式:doc, xls, ppt, pdf, docx, xlsx, pptx。

建议给用户添加一句提示,下载下来的文件会自动打开

复制代码
// html
<view class="submitBtn btn" @click="submitExport">导出</view>


submitExport(){
	uni.showModal({
		content:"导出的Excel文件将自动打开,请点击右上角"更多"选择保存",
		title:"温馨提示",
		success(res) {
			if(res.confirm){
				this.export()
			}
		}
	})
},
export(){
// 请求用自己项目的封装请求,我这用了我自己项目的
	this.$http.mallbusiness({
		url: "写自己后端给的接口",
			data: this.queryString,
			type: "queryString",
		}).then(res => {
		if (res.code == 200) {
			uni.downloadFile({
				url: res.data,
				success: (downloadRes) => {
					console.log(downloadRes,"downloadRes")
					if (downloadRes.statusCode === 200) {
						// 文件临时路径
						const tempFilePath = downloadRes.tempFilePath;
						
						//打开文件
						uni.openDocument({
							filePath: tempFilePath,
							showMenu: true,
							success: () => {
								this.$u.toast("导出成功!");
								this.exportClose()
							},
							fail: (err) => {
								console.error('打开文件失败', err);
								this.$u.toast("文件已下载,但无法打开");
							}
						});
					} else {
						this.$u.toast("下载失败,请重试");
					}
				},
				fail: (err) => {
					console.error('下载文件失败', err);
					this.$u.toast("下载失败,请重试");
				},
				complete: () => {
					uni.hideLoading();
				}
			});
		} else {
			this.$u.toast(res.message)
		}
	})
},
相关推荐
雪芽蓝域zzs1 小时前
uniapp 数组的用法
前端·javascript·uni-app
meng半颗糖1 小时前
uniapp 基础(三)
前端·uniapp·notepad++·uniapp基础
大阳光男孩1 小时前
Uniapp生物识别(SOTER)
uni-app
艾普阳科技1 小时前
SnapDevelop支持uni-app开发:跨平台与原生体验的完美融合
uni-app·跨平台开发
说私域3 小时前
企业通讯与营销技术融合创新:定制开发开源AI智能名片S2B2C商城小程序的协同价值研究
人工智能·小程序·开源
程序员老刘4 小时前
uni-app X能成为下一个Flutter吗?
flutter·uni-app·客户端
2501_916007475 小时前
iOS 文件管理实战指南 查看 App 数据与系统日志的完整方法
android·ios·小程序·https·uni-app·iphone·webview
2501_915106326 小时前
iOS 内测上架流程详解:跨平台团队如何快速部署 TestFlight
android·ios·小程序·https·uni-app·iphone·webview
白白白鲤鱼7 小时前
Vue2项目—基于路由守卫实现钉钉小程序动态更新标题
服务器·前端·spring boot·后端·职场和发展·小程序·钉钉
sunjay1179 小时前
uniapp 通用地磅称重系统手机端
uni-app