uni-app应用更新(Android端)

2024-09-05 01:52
文章标签 android 应用 app 更新 uni

本文主要是介绍uni-app应用更新(Android端),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关于app更新,uni-app官方推荐的是 uni-upgrade-center,看了下比较繁琐,因此这里自己实现检查更新并下载安装的逻辑。

1.界面效果

               

界面中的弹框和 进度条采用了uView 提供的组件

2.检查更新并下载安装

一、版本信息配置在服务端,请求服务端接口判断是否需要更新 。

二、点击下载按钮,则开始下载App安装包,并监听下载进度,实时更新下载进度条

注意:下载App如果是在浏览器测试,可能会有跨域的问题,需要后端服务允许跨域。

三、待下载完成后开始安装。

安装App采用的是 uni-installApk插件,请自行导入项目

uni-installApk - DCloud 插件市场

3.完整代码 

update.vue

<template><u-modal :show="show"   :showConfirmButton="false"><view class="box-a4"><image class="img-up" mode="widthFix" src="https://beilizhengxuan.oss-cn-hangzhou.aliyuncs.com/huayu/update.png"/><view class="box-a5"><text>发现新版本V{{version}},升级后体验更顺畅</text></view><view class="row-b0" v-if="!startDownload"><view class="btn0" @click="downLoadApp" >马上更新</view><view class="btn0 white" color=""  @click="cancel"v-if="forceUpdata=='0'">暂不更新</view></view><view v-if="startDownload" class="row-b1"><view class="te-j0">下载进度</view><u-line-progress :percentage="percent" height="24"activeColor="#3c9cff"></u-line-progress></view></view></u-modal>
</template>
<script>
import {getAppNewVersion} from '@/api/system/user'
export default{props:{},data(){return{startDownload: false, //是否开始下载show: false,version: '',forceUpdata: '',//是否需要强制更新apkDownloadUrl: '',//percent: 0,filePath: '',}},created(){this.handleToUpgrade()},computed:{showUpdate(){console.log('this.$stroe.state.user',this.$stroe.state.user)return this.$stroe.state.user.showUpdate}},methods:{async handleToUpgrade() {const sysInfo = uni.getSystemInfoSync()const appVersion = sysInfo.appVersionconsole.log('appVersion', appVersion)//请求服务端检查更新接口,判断是否需要更新const res = await getAppNewVersion()if(res.code == 200){if(res.data && res.data.newVersion){const newVersion = res.data.newVersionif(appVersion == newVersion){this.showToast('当前已是最新版本')this.cancel()} else{this.apkDownloadUrl = res.data.apkDownloadUrlthis.show = trueconsole.log('需要更新')this.version = newVersionthis.forceUpdata =  res.data.forceUpdata}}}},installApp(){uni.installApk({filePath : this.filePath,success: (res)=>{console.log('安装成功--', res);},fail : (res)=>{console.log('安装失败--', res);},complete: (res)=>{console.log('安装完成--', res);}})},downLoadApp(){this.startDownload = trueconst downloadTask = uni.downloadFile({url: this.apkDownloadUrl , //仅为示例,并非真实的资源timeout: 6000000,success: (res) => {console.log('success res', res)if (res.statusCode === 200) {this.filePath = res.tempFilePathconsole.log('下载成功');this.cancel()this.installApp()}},complete: (res)=> {console.log('complete res', res)},fail: (res)=> {console.log('fail res', res)},});downloadTask.onProgressUpdate((res) => {//console.log('下载进度' + res.progress);//console.log('已经下载的数据长度' + res.totalBytesWritten);//console.log('预期需要下载的数据总长度' + res.totalBytesExpectedToWrite);this.percent = res.progressif (res.progress >= 100) {console.log('下载进度 abort' + res.progress);//downloadTask.abort();}});},cancel(){this.$emit('cancel')this.show = false},showToast(message){uni.showToast({title: message,icon: 'none'})}}
}
</script><style>.img-up{width: 100%;}.box-a4{width: 100%;display: flex;flex-direction: column;justify-content: flex-start;}.box-a5{flex:1;text-align: center;font-size: 28rpx;color: #999;padding: 20rpx 0;}.row-b0{display:flex;flex-direction: row;justify-content: space-around;align-items: center;padding: 0 50rpx;margin-top:60rpx;margin-bottom:60rpx;}.row-b0 .btn0{width: 240rpx;height: 68rpx;border-radius: 34rpx;color: white;display: grid;place-content: center;background:#3c9cff;}.row-b0 .btn0:active{opacity: 0.7;}.row-b0 .btn0.white{background:#fff;color: #666;border:1px solid #eee;}.row-b1{margin: 60rpx 40rpx;}.te-j0{text-align: center;color:#999;font-size: 26rpx;margin-bottom:20rpx;}
</style>

 4.引入并使用

上面将检查更新的逻辑封装在了update.vue中,使用时只需引入该组件,在父页面点击检查更新按钮时,只需将 checkUpdate 属性设置为 true,则加载 update.vue组件,进入created 方法并调用检查更新的相关逻辑,有新版本则弹框,提示更新,无新版本则将 checkUpdate重置为 false

注意:当检查更新的弹框弹出时,调用页面需要禁用 android的 返回按键,在  onBackPress函数里面做相应的逻辑判断即可。

<template><view ><UpdateApp v-if="checkUpdate" @cancel="checkUpdate=false"/></view>
</template>
<script>
import UpdateApp from './update'export default {components:{UpdateApp},data() {return {checkUpdate: false,}},onBackPress(options) {console.log('onBackPress options', options)// 禁用返回if (options.from == 'backbutton') {console.log('--禁用返回')if(this.checkUpdate){return true;// 禁用返回按键}else {return false;}}},methods: {}}
</script>
<style lang="scss" scoped></style>

这篇关于uni-app应用更新(Android端)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1137633

相关文章

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

Java 缓存框架 Caffeine 应用场景解析

《Java缓存框架Caffeine应用场景解析》文章介绍Caffeine作为高性能Java本地缓存框架,基于W-TinyLFU算法,支持异步加载、灵活过期策略、内存安全机制及统计监控,重点解析其... 目录一、Caffeine 简介1. 框架概述1.1 Caffeine的核心优势二、Caffeine 基础2

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

Android实现图片浏览功能的示例详解(附带源码)

《Android实现图片浏览功能的示例详解(附带源码)》在许多应用中,都需要展示图片并支持用户进行浏览,本文主要为大家介绍了如何通过Android实现图片浏览功能,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

在Android中使用WebView在线查看PDF文件的方法示例

《在Android中使用WebView在线查看PDF文件的方法示例》在Android应用开发中,有时我们需要在客户端展示PDF文件,以便用户可以阅读或交互,:本文主要介绍在Android中使用We... 目录简介:1. WebView组件介绍2. 在androidManifest.XML中添加Interne

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

Android协程高级用法大全

《Android协程高级用法大全》这篇文章给大家介绍Android协程高级用法大全,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友跟随小编一起学习吧... 目录1️⃣ 协程作用域(CoroutineScope)与生命周期绑定Activity/Fragment 中手