【UNI-APP 开发 - 必看教程】APP 自动更新(进度条)

本贴最后更新于 933 天前,其中的信息可能已经物是人非

自动更新:DownLoader

Downloader 模块管理网络文件下载任务,用于从服务器下载各种文件,并支持跨域访问操作。通过 plus.downloader 获取下载管理对象。Downloader 下载使用 HTTP 的 GET/POST 方式请求下载文件,符合标准 HTTP/HTTPS 传输协议。

方法:

createDownload 新建下载任务
enumerate 枚举下载任务
clear 清除下载任务
startAll 开始所有下载任务

对象:

Download 管理一个下载任务
DownloadEvent 下载任务事件类型
DownloadState 下载任务状态
DownloadOptions 下载任务参数

回调方法:

DownloadCompletedCallback 下载任务完成时的回调
DownloadStateChangedCallback 下载任务状态变化回调
DownloadEnumerateCallback 枚举下载任务回调

使用: plus.downloader.createDownload(url,option,completedCB)

说明:

请求下载管理创建新的下载任务,创建成功则返回 Download 对象,用于管理下载任务。

参数:

url: ( String ) 必选 要下载文件资源地址
要下载文件的 url 地址,仅支持网络资源地址,支持 http 或 https 协议。 允许创建多个相同 url 地址的下载任务。 注意:如果 url 地址中包含中文或空格等,需要进行 urlencode 转换。

options: ( DownloadOptions ) 可选 下载任务的参数
可通过此参数设置下载任务属性,如保存文件路径、下载优先级等。

completedCB: ( DownloadCompletedCallback ) 可选 下载任务完成回调函数
当下载任务下载完成时触发,成功或失败都会触发。

返回值:

新建的下载任务对象

附代码:

createDownload(url) {
	var dtask = plus.downloader.createDownload(url, {},
		function(d, status) {
			uni.showToast({
				title: '下载完成',
				mask: false,
				duration: 1000
			});
			// 下载完成
			console.log('status: ' + status);
			if (status == 200) {
				console.log('下载成功:' + d.filename);
				console.log('plus.io.convertLocalFileSystemURL(d.filename): ' + plus.io
					.convertLocalFileSystemURL(d.filename))
				plus.runtime.install(plus.io.convertLocalFileSystemURL(d.filename), {}, function(success) {
					uni.showToast({
						title: '安装成功',
						mask: false,
						duration: 1500
					});
				}, function(error) {
					uni.showToast({
						title: '安装失败-01',
						mask: false,
						duration: 1500
					});
				})
			} else {
				uni.showToast({
					title: '更新失败-02',
					mask: false,
					duration: 1500
				});
			}
		});
	try {
		dtask.start(); // 开启下载的任务
		var prg = 0;
		var showLoading = plus.nativeUI.showWaiting("正在下载"); //创建一个showWaiting对象

		dtask.addEventListener('statechanged', function(task, status) {
			console.log('自动更新测试1:',task)
			console.log('自动更新测试2:',status)
			// 给下载任务设置一个监听 并根据状态  做操作
			switch (task.state) {
				case 1:
					showLoading.setTitle("正在下载");
					break;
				case 2:
					showLoading.setTitle("已连接到服务器");
					break;
				case 3:
					prg = parseInt((parseFloat(task.downloadedSize) / parseFloat(task.totalSize)) *
						100);
					showLoading.setTitle("  正在下载" + prg + "%  ");
					break;
				case 4:
					plus.nativeUI.closeWaiting();
					//下载完成
					break;
			}
		});
	} catch (err) {
		console.log('错误信息',err)
		plus.nativeUI.closeWaiting();
	}
}

思路:

1:初始化,调用后台更新接口

2:获取当前 APP 应用版本号,和应用版本名称

3:根据接口返回的数据判断是否需要更新,

4:不需要则提示,需要则进行以上代码更新的操作

附官网文档链接:HTML5+ API Reference

版权声明

作者:王时信

出处:https://blog.csdn.net/Power_Blogger/article/details/123089729

未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接,否则保留追究法律责任的权利.

  • Vue.js

    Vue.js(读音 /vju ː/,类似于 view)是一个构建数据驱动的 Web 界面库。Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

    265 引用 • 666 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...