uniapp版本升级

ops/2025/1/31 7:49:53/

1.样式

登录进到首页,弹出更新提示框,且不可以关闭,侧边返回直接退出!

有关代码:

<uv-popup ref="popupUpdate" round="8" :close-on-click-overlay="false"><view style="width: 450rpx; display: flex; flex-direction: column; align-items: center; padding: 20rpx 0 50rpx 0"><text style="font-size: 23px">提示</text><text style="font-size: 18px; margin-top: 20rpx">发现新版本,立即升级!</text><view style="margin-top: 30rpx"><uv-button size="normal" type="primary" @click="sureUpdate" :customStyle="{ width: '300rpx' }">确认</uv-button></view></view></uv-popup>

2.操作代码

javascript">const sureUpdate = () => {showFly(true, '');
};
const showFly = (isShowCancel, url) => {if (true) {// clearInterval(updateAction)uni.showLoading({title: '更新中……'});try {const appUrl = config.appDownloadUrl;const downloadTask = uni.downloadFile({url: appUrl, // 这个是最新版本apk包的地址success: (res) => {uni.hideLoading();if (res.statusCode === 200) {console.log('res.tempFilePath :>> ', res.tempFilePath);plus.runtime.install(res.tempFilePath,{force: true},(_res) => {uni.showToast({title: '更新成功,重启中',duration: 1600});popupUpdate.value.close();plus.runtime.restart();uni.hideToast();});} else {uni.showToast({title: '下载失败!',icon: 'none',duration: 800});}}});// 下载进度downloadTask.onProgressUpdate((res) => {// _this.startDown = true;// _this.calcPro(res.progress);console.log('下载进度' + res.progress);// console.log('已经下载的数据长度' + res.totalBytesWritten);// console.log('预期需要下载的数据总长度' + res.totalBytesExpectedToWrite);// // 测试条件,取消下载任务。// if (res.progress > 50) {//     downloadTask.abort();// }});} catch (error) {console.log('error :>> ', error);uni.hideLoading();} finally {}}
};

2.是否更新

在进到首页最重要的一环就是判断系统是否需要更新,在onShow里使用

如果接口返回的版本>系统现在本身的版本号,那么就弹出提示框!

javascript">nextTick(() => {// popupUpdate.value.open();isUpdate();});
const isUpdate = () => {const WXP_APP_VERSION = uni.getStorageSync('appVersion');const curVersion = uni.getStorageSync('version'); // 当前版本let str = WXP_APP_VERSION.split('.').join('');let str1 = curVersion.split('.').join('');console.log(Number(str));console.log(Number(str1));if (curVersion && WXP_APP_VERSION) {if (Number(str) > Number(str1)) {popupUpdate.value.open();} else {popupUpdate.value.close();}} else {popupUpdate.value.close();}
};


http://www.ppmy.cn/ops/154422.html

相关文章

Vuex中的getter和mutation有什么区别

在现代前端开发中&#xff0c;状态管理是一个不可忽视的话题&#xff0c;而Vuex作为Vue.js的官方状态管理库&#xff0c;在大型应用中扮演着至关重要的角色。当我们使用Vuex进行状态管理时&#xff0c;getter和mutation是两个重要的概念。虽然它们都是用来处理状态的&#xff0…

三天急速通关JavaWeb基础知识:Day 2 前端基础知识(计划有变,前端工程化部分暂时搁置)

三天急速通关JavaWeb基础知识&#xff1a;Day 2 前端基础知识 0 文章说明1 HTML1.1 介绍1.2 基本结构及语法1.3 常见标签2 CSS2.1 介绍2.2 引入方式2.3 选择器2.4 浮动 定位 盒子模型 3 JavaScript3.1 介绍3.2 组成3.3 基础语法 4 Ajax4.1 介绍4.2 示例 未完待续&#xff0c;前…

图神经网络驱动的节点分类:从理论到实践

图神经网络驱动的节点分类:从理论到实践 1. 引言 图神经网络(Graph Neural Networks,GNN)作为处理图结构数据的强大工具,近年来在学术界和工业界都取得了显著进展。其独特的消息传递机制能够有效捕捉图数据中的复杂关系,为节点分类、链接预测、图分类等任务提供了新的解…

Autogen_core: ClosureAgent使用与测试

目录 第一个示例第二个示例完成的功能 下面两个示例展示了如何使用 AutoGen 库中的 ClosureAgent 来创建和使用代理。 ClosureAgent 允许你使用闭包&#xff08;即一个没有定义类的函数&#xff09;来定义代理&#xff0c;并从运行时中提取值。代码中展示了两个示例&#xff…

MySQL(高级特性篇) 13 章——事务基础知识

一、数据库事务概述 事务是数据库区别于文件系统的重要特性之一 &#xff08;1&#xff09;存储引擎支持情况 SHOW ENGINES命令来查看当前MySQL支持的存储引擎都有哪些&#xff0c;以及这些存储引擎是否支持事务能看出在MySQL中&#xff0c;只有InnoDB是支持事务的 &#x…

CF 764B.Timofey and cubes(Java实现)

题目分析 输入n个数字&#xff0c;首尾交换&#xff0c;奇数对换&#xff0c;偶数对不换 思路分析 存入数组&#xff0c;遍历时判断i%20时(数组下标0开始&#xff0c;所以题目分析没有错)&#xff0c;对换 代码 import java.util.*;public class Main {public static void ma…

第十四讲 JDBC数据库

1. 什么是JDBC JDBC&#xff08;Java Database Connectivity&#xff0c;Java数据库连接&#xff09;&#xff0c;它是一套用于执行SQL语句的Java API。应用程序可通过这套API连接到关系型数据库&#xff0c;并使用SQL语句来完成对数据库中数据的查询、新增、更新和删除等操作…

5分钟带你获取deepseek api并搭建简易问答应用

目录 1、获取api 2、获取base_url和chat_model 3、配置模型参数 方法一&#xff1a;终端中临时将加入 方法二&#xff1a;创建.env文件 4、 配置client 5、利用deepseek大模型实现简易问答 deepseek-v3是截止博文撰写之日&#xff0c;无论是国内还是国际上发布的大模型中…