uniapp 安卓apk自动更新,进度显示

App.vue

安卓原生api学习地址

onLaunch: function() {
			// #ifdef APP-PLUS
			plus.runtime.getProperty(plus.runtime.appid, function(res) {
				console.log("当前应用版本号", res.version);
				'你的接口查询服务端的版本号'().then(v => {
					console.log("服务器版本号", v.data);
					if (res.version !== v.data) {
						uni.showModal({
							title: "提示",
							content: "发现新的应用安装包,点击确定立即更新",
							success(s) {
								if (s.confirm) {
									let showLoading = plus.nativeUI.showWaiting(
									"正在下载"); //创建一个showWaiting对象
									console.log("用户点击更新");
									const downloadTask = uni.downloadFile({
										// 下载文件
										url: "服务端apk地址.apk",
										success(load) {
											console.log('更新成功', load);
											// 关闭loading
											plus.nativeUI.closeWaiting();

											plus.runtime.install(load
												.tempFilePath, { force: false },
												function() {
													console.log("安装成功");
													plus.runtime.restart();
												},
												function(e) {
													plus.nativeUI.closeWaiting();
													// 安装失败,请检查apk包是否解析正常
													console.log("安装失败");
												})
										},
										fail(err) {
											plus.nativeUI.closeWaiting();
											console.log("更新失败", err);
										},
									});
									downloadTask.onProgressUpdate((res) => {
										showLoading.setTitle(" 正在下载" + res.progress +
											"% ");
										// console.log('下载进度' + res.progress);
										// console.log('已经下载的数据长度' + res.totalBytesWritten);
										// console.log('预期需要下载的数据总长度' + res.totalBytesExpectedToWrite);

										// 满足测试条件,取消下载任务。
										// if (res.progress > 50) {
										// downloadTask.abort();
										// plus.nativeUI.closeWaiting();
										// }
									})
								} else {
									console.log("用户取消更新");
								}
							}
						})
					} else {
						console.log("无需更新");
					}
				})
			})
			// #endif
		},

  • 11
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值