跨平台应用开发进阶(十五) :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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 皮尔森相关系数(Pearson correlation coefficient)「建议收藏」

    皮尔森相关系数(Pearson correlation coefficient)「建议收藏」概述定义物理意义皮尔森距离机器学习中的应用代码实现概述皮尔森相关系数也称皮尔森积矩相关系数(Pearsonproduct-momentcorrelationcoefficient),是一种线性相关系数,是最常用的一种相关系数。记为r,用来反映两个变量X和Y的线性相关程度,r值介于-1到1之间,绝对值越大表明相关性越强。定义总体相关系数ρ定义为两…

    2022年4月20日
    599
  • IDEA主题插件:Material Theme UI「建议收藏」

    IDEA主题插件:Material Theme UI「建议收藏」大致效果如下:IDEA官方下载MaterialThemeUI步骤:Settings->Plugins->搜索Translation(某些版本IDEA搜索插件有问题可到官网下载再安装本地插件)->安装->重启IDEA->首次根据提示进行UI相关配置->使用配置后的UI如需离线安装插件参考如下:如需修改配置项参考如下:注…

    2022年6月27日
    220
  • [转] Vue生命周期

    [转] Vue生命周期

    2022年3月2日
    44
  • Java使用HttpURLConnection上传文件

    Java使用HttpURLConnection上传文件

    2022年1月23日
    43
  • Openssl Heartbleed

    Openssl Heartbleed近日闹的沸沸扬扬的Heartbleed漏洞,仿佛一下子再次将人们拉回了对网络安全的关注和担忧。这个问题就是由于服务器端没有对用户发过来的心跳包数据进行边界检查,服务端根据用户心跳包指定的数据长度来返回同样长度的数据。如果用户指定长度为100字节,而实际心跳数据的长度只有1字节,服务端还是会memcpy长度100字节的数据,这样就会把服务端内存中的数据返回给用户,可能会…

    2022年7月15日
    16
  • vue怎么关闭eslint_如何关闭eslint

    vue怎么关闭eslint_如何关闭eslint@[TOC]VUE关闭eslint严格模式VUE关闭eslint严格模式如果在使用vue@cli搭建vue工程时,不小心选择了eslint严格校验模式,对于开发人员调试代码是很麻烦的事,那么如何关掉eslint严格模式呢?1.在package.json文件下找到eslint配置”eslintConfig”:{“root”:true,”env”:{“node”:true},”extends”:[“plugin:vu

    2022年10月8日
    4

发表回复

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

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