uniapp下载文件的方案,包括H5,App方案解决办法

  1. 在uniapp需要下载文件,但是显示情况是不能下载。所以只能使用该办法来进行下载。

  2. 这有一个注意点是:如果你做的是H5的方案,那么我已经替你踩好坑了,UC浏览器是不支持blob类型的下载,以及创建a标签的方案来进行下载。目前发现只有QQ浏览器支持这两种方案。如果你是保密单位,QQ浏览器其实也是可以,因为也是国产化的浏览器。

代码体现:

首先获取后端给你返回的文件下载地址:

javascript 复制代码
mounted() {
			this.fatIdList = this.config.modelId
			this.$refs.uToast.show({
				type: 'warning',
				icon: false,
				title: '若UC浏览器无法下载模板,请使用QQ浏览器下载!',
				duration: 3000,
			})
			deliverDownloadApi(this.fatIdList, {
				"currentPage": 1,
				"pageSize": 20,
				"sort": "desc",
				"sidx": "",
				"menuId": this.fatIdList,
				"queryJson": "",
				"superQueryJson": '',
				"idList": [],
				"dataType": "1",
				"selectKey": []
			}).then(data => {
				this.fileUrl = this.define.baseURL + data.data.url
				this.download()
			})
		},

第二步:调取uniapp的原始下载方法uni.downloadFile

javascript 复制代码
// 点击下载
			download() {
				setTimeout(() => {
					// 更多参数,详见文档
					// https://uniapp.dcloud.net.cn/uni-app-x/api/download-file.html#downloadfile
					uni.downloadFile({
						url: this.fileUrl, //下载地址
						header: this.header, //HTTP请求Header
						timeout: 150000, //下载超时时间(毫秒)
						success: (res) => {
							// 利用临时地址调起下载
							this.arouse(res)
						},
						fail: (err) => {
							console.log('下载失败', err)
						}
					})
				}, 3000)
			},

第三步:

创建a标签的方法来下载:

javascript 复制代码
// 利用临时地址调起下载
			arouse(res) {
				let date = new Date()
				let file_name = '退换货管理(标准化)' + this.dateFormat(date)
				// eslint-disable-next-line camelcase
				let file_type = 'xlsx'
				// console.log(res)
				var oA = document.createElement("a")
				// 设置下载的文件名
				oA.download = `${file_name}.${file_type}`
				// Blob临时路径再保存到本地
				oA.href = res.tempFilePath
				// 插入DOM并执行点击下载
				document.body.appendChild(oA)
				oA.click()
				oA.remove()
			},

第四步:直接打开QQ浏览器开始下载

相关推荐
2501_9159090611 小时前
全面解析前端开发中常用的浏览器调试工具及其使用场景
android·ios·小程序·https·uni-app·iphone·webview
wuxianda103011 小时前
uniapp项目上架苹果商店4.3a被拒,3天极速解决方案2026.5.8
前端·人工智能·flutter·uni-app·ios上架·苹果上架·苹果4.3a
小盼江17 小时前
Uniapp小程序鲜花商城推荐系统 买家卖家双端(web+uniapp)
前端·小程序·uni-app
fakaifa18 小时前
【最新版】CRMEB Pro版v4.0系统源码 全开源+uniapp/PC前端+搭建教程
uni-app·开源·商城小程序·crmeb·crmebpro
小徐_23331 天前
Wot UI v1 升级 v2?这份迁移指南帮你少踩坑!
前端·微信小程序·uni-app
游戏开发爱好者82 天前
使用Fiddler设置HTTPS抓包诊断Power Query网络问题
android·ios·小程序·https·uni-app·iphone·webview
棋宣2 天前
uni-app编译到微信小程序中,父传子props首次传递数据不接收的bug
微信小程序·uni-app·bug
阳光先做3 天前
uniapp打包鸿蒙安装包问题
uni-app
码海扬帆:前端探索之旅3 天前
深度定制 uni-combox:新增功能详解与实战指南
前端·vue.js·uni-app
计算机学姐3 天前
基于微信小程序的图书馆座位预约系统【uniapp+springboot+vue】
vue.js·spring boot·微信小程序·小程序·java-ee·uni-app·intellij-idea