zoukankan      html  css  js  c++  java
  • uniapp 小程序新版本发布提示用户更新

    小程序发布新版本因为发版本是异步执行,所以要再一段时间后新版本才会覆盖旧版本。

    小程序的启动方式分为两种,冷启动与热启动:

    冷启动:用户首次打开或小程序被用户删除后再次打开时小程序需要重新加载启动。
    热启动:用户已经打开过某小程序,然后在一定时间内再次打开该小程序,不会重新加载启动,只是将后台状态的小程序切换到前台状态。

    uniapp提供了版本更新管理器对象的API: uni.getUpdateMansger

    平台差异说明

    AppH5微信小程序支付宝小程序百度小程序字节跳动小程序、飞书小程序QQ小程序快手小程序
    x x

    官方案例代码:

    const updateManager = uni.getUpdateManager();
    
    updateManager.onCheckForUpdate(function (res) {
      // 请求完新版本信息的回调
      console.log(res.hasUpdate);
    });
    
    updateManager.onUpdateReady(function (res) {
      uni.showModal({
        title: '更新提示',
        content: '新版本已经准备好,是否重启应用?',
        success(res) {
          if (res.confirm) {
            // 新的版本已经下载好,调用 applyUpdate 应用新版本并重启
            updateManager.applyUpdate();
          }
        }
      });
    
    });
    
    updateManager.onUpdateFailed(function (res) {
      // 新的版本下载失败
    });
    

    updateManager 对象的方法列表:

    方法参数说明
    onCheckForUpdate callback 当向小程序后台请求完新版本信息,会进行回调
    onUpdateReady callback 当新版本下载完成,会进行回调
    onUpdateFailed callback 当新版本下载失败,会进行回调
    applyUpdate   当新版本下载完成,调用该方法会强制当前小程序应用上新版本并重启

    onCheckForUpdate(callback) 回调结果说明:

    属性类型说明
    hasUpdate Boolean 是否有新的版本

    把官方代码调整后放在 App.vue文件的onLaunch事件里

    onLaunch(){
         //定义更新方法 function VersionUpdate() { // 判断应用的 getUpdateManager 是否在当前版本可用 if (uni.canIUse('getUpdateManager')) { const updateManager = uni.getUpdateManager() // 向小程序后台请求完新版本信息 updateManager.onCheckForUpdate(function(res) { if (res.hasUpdate) { //小程序有新版本,静默下载新版本,新版本下载完成 updateManager.onUpdateReady(function() {
                  //模态弹窗(确认、取消) uni.showModal({ title: '更新提示', content: '小程序已发布新版本,是否重启?', success: function(res) {
                       //用户点击确定 if (res.confirm) { //当新版本下载完成,调用该方法会强制当前小程序应用上新版本并重启 updateManager.applyUpdate() }
                       //用户点击取消
                       else if (res.cancel) { //强制用户更新,弹出第二次弹窗 uni.showModal({ title: '提示', content: '小程序已发布新版本,是否重启', showCancel: false, //隐藏取消按钮 success: function(res) { //第二次提示后,强制更新 if (res.confirm) { // 当新版本下载完成,调用该方法会强制当前小程序应用上新版本并重启 updateManager.applyUpdate() } } }) } } }) }) // 当新版本下载失败 updateManager.onUpdateFailed(function() { uni.showModal({ title: '提示', content: '请您删除当前小程序,重新打开小程序', }) }) } }) } else { // 提示用户在最新版本的客户端上体验 uni.showModal({ title: '温馨提示', content: '当前微信版本过低,可能无法使用该功能,请升级到最新版本后重试。' }) } }
         //调用定义的更新方法 VersionUpdate(); },

    测试版本更新效果:

    微信开发者工具 —— 选择添加编译模式 —— 编译设置 —— 下次编译时模拟更新 —— 更新状态

  • 相关阅读:
    【bzoj2190】: [SDOI2008]仪仗队 数论-欧拉函数
    【bzoj2751】[HAOI2012]容易题(easy) 数论-快速幂
    【bzoj2186】: [Sdoi2008]沙拉公主的困惑 数论-欧拉函数
    这里会有你想要的,已收录css , js相关文章
    Vue源码解析--实现一个指令解析器 Compile
    九宫格抽奖
    12行代码简单实现跑马灯文字匀速滚动
    滑弯曲弧形效果的插件-arctext.js改造
    几种拼图小游戏封装
    倒计时
  • 原文地址:https://www.cnblogs.com/Intellectualscholar/p/15793755.html
Copyright © 2011-2022 走看看