跨平台应用开发进阶(十五) :uni-app 自定义 showToast并实现下载进度条

跨平台应用开发进阶(十五) :uni-app 自定义 showToast并实现下载进度条大话设计模式(四)单例模式的优与劣前言首先来明确一个问题,那就是在某些情况下,有些对象,我们只需要一个就可以了,比如,一台计算机上可以连好几个打印机,但是这个计算机上的打印程序只能有一个,这里就可以通过单例模式来避免两个打印作业同时输出到打印机中,即在整个的打印过程中我只有一个打印程序的实例。简单说来,单例模式(也叫单件模式)的作用就是保证在整个应用程序的生命周期中,任何一个时刻,

大家好,又见面了,我是你们的朋友全栈君。

一、前言

在《跨平台应用开发进阶(七) :uni-app 自定义 showToast》中讲解了利用uni-app跨平台开发框架开发多终端APP时,应用HBuilder自身提供的弹窗不满足业务需求,故开发自定义弹窗组件showToast。

二、代码实现

应用自定义 showToast在实现版本更新时,需要实现检测到APP发新版时,可以更新下载新版本,并显示下载进度条。状态管理模块实现如下:

// 开始下载任务
const downloadTask = uni.downloadFile({
		url: data.url,
		// 接口调用成功
		success: (downloadResult) => {
			uni.hideLoading();
			if (downloadResult.statusCode === 200) {
				plus.runtime.install(downloadResult.tempFilePath, {
						force: false
				}, function() {
					plus.runtime.restart();
				}, function(e) {
					console.error('install fail...');
					});
					}
				},
		// 接口调用失败
		fail: (err) => {
			uni.showToast({
				icon:'none',
				mask:true,
				title: '安装失败,请重新下载',
			});
		},
		// 接口调用结束
		complete: () => {
			downloadTask.offProgressUpdate(); //取消监听加载进度
		}
	});

	//监听下载进度
	downloadTask.onProgressUpdate(res => {
		state.percent = res.progress;
		// console.log('下载进度百分比:' + res.progress); // 下载进度百分比
		// console.log('已经下载的数据长度:' + res.totalBytesWritten); // 已经下载的数据长度,单位 Bytes
		// console.log('预期需要下载的数据总长度:' + res.totalBytesExpectedToWrite); // 预期需要下载的数据总长度,单位 Bytes
	});

视图部分实现如下:

<view v-if="downLineShow" style="width: 80%; height: 30rpx;">
	<text>新版本下载中,请稍等</text>
	<progress :percent="percent" font-size='24rpx' border-radius='44rpx' activeColor='#D52424' show-info stroke-width="10"></progress>
</view>

三、拓展阅读

hello uni-app

progress | uni-app官网

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/151219.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 数据仓库和数据集市详解:ODS、DW、DWD、DWM、DWS、ADS「建议收藏」

    数据仓库和数据集市详解:ODS、DW、DWD、DWM、DWS、ADS「建议收藏」@TOC数据流向应用示例何为数仓DWDatawarehouse(可简写为DW或者DWH)数据仓库,是在数据库已经大量存在的情况下,它是一整套包括了etl、调度、建模在内的完整的理论体系。数据仓库的方案建设的目的,是为前端查询和分析作为基础,主要应用于OLAP(on-lineAnalyticalProcessing),支持复杂的分析操作,侧重决策支持,并且提供直观易懂的查询结果。目前行业比较流行的有:AWSRedshift,Greenplum,Hive等。数据仓库并不是数据的最终目的地

    2022年6月26日
    97
  • java环境配置——cmd命令行输入java正常显示而javac则显示不是内部或者外部命令[通俗易懂]

    java环境配置——cmd命令行输入java正常显示而javac则显示不是内部或者外部命令[通俗易懂]重装系统之后第二发,配置pycharm,意料之外的错误,启动的时候竟然要求配置jdk,瞬时蒙蔽,不记得之前有这么一出啊,上图:于是乎就去官网下载了jdk:找到适合自己的版本,我选的最后一个windows64位的,下载好之后直接安装就行,貌似这里不会有啥问题:安装完成需要在配置环境变量,这样系统才能找到我们的java命令,具体的原理大家可以搜一下,网上讲的很清楚~~环境变…

    2022年5月28日
    46
  • 百度搜索引擎

    百度搜索引擎

    2021年10月9日
    80
  • 在docker 上安装lnmp 环境

    在docker 上安装lnmp 环境

    2022年2月19日
    37
  • cdn加速以及前后分离SpringBoot+Vue 配置https及SSL证书「建议收藏」

    cdn加速以及前后分离SpringBoot+Vue 配置https及SSL证书「建议收藏」配置方法同上篇文章一样CDN加速配置,阿里云cdn内配置好以后即可剩下把前端服务器nginx内的证书文件上传以及配置写好即可。后端服务器也同上配置证书下载上传服务器配置好nginx即可。如果都配置好以后,不可以访问时,注意查看前端请求接口是否为https方式。如果为http时,检查是否更新服务器成功,如果成功后还不可以正常访问时,前端修改代码如下:vue.config.js内添加下行代码。index.html下添加代码:https:true完毕!…

    2022年8月19日
    4
  • 狂神说SpringCloud学习笔记[通俗易懂]

    狂神说SpringCloud学习笔记[通俗易懂]注:本文根据哔哩哔哩Up主狂神老师:狂神说Java所讲的springcloud课程所作的笔记,狂神老师springcloud哔哩哔哩视频连接:https://www.bilibili.com/video/BV1jJ411S7xr?p=18spring,课程代码可用在狂神老师的Java交流群中获取,或者到我的码云仓库https://gitee.com/cao_shi_peng/dashboard/projects获取,如果想进一步深入学习springcloud详细内容可自行参考Spring

    2022年5月1日
    51

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号