小程序开发API之更新管理器wx.getUpdateManager()、UpdateManager

wx.getUpdateManager()
获取全局唯一的版本更新管理器,用于管理小程序更新。关于小程序的更新机制

注:
更新机制

       小程序冷启动时如果发现有新版本,将会异步下载新版本的代码包,并同时用客户端本地的包进行启动,即新版本的小程序         需要等下一次冷启动才会应用上。 如果需要马上应用最新版本,可以使用 wx.getUpdateManager API 进行处理。
运行机制
       小程序没有重启的概念
              当小程序进入后台,客户端会维持一段时间的运行状态,超过一定时间后(目前是5分钟)会被微信主动销毁
              在 iOS 上,当微信客户端在一定时间间隔内(目前是 5 秒)连续收到两次及以上系统内存告警时,会主动进行小程序                  的销毁,并提示用户 「该小程序可能导致微信响应变慢被终止」。建议小程序在必要时使用 wx.onMemoryWarning 监                听内存告警事件,进行必要的内存清理。
       返回值
              UpdateManager
              UpdateManager 对象,用来管理更新,可通过 wx.getUpdateManager 接口获取实例。

        方法

        UpdateManager.applyUpdate()
               强制小程序重启并使用新版本。在小程序新版本下载完成后(即收到 onUpdateReady 回调)调用。

        UpdateManager.onCheckForUpdate(function callback)
               监听向微信后台请求检查更新结果事件。微信在小程序冷启动时自动检查更新,不需由开发者主动触发。
        参数function callback
               向微信后台请求检查更新结果事件的回调函数


        UpdateManager.onUpdateReady(function callback)
                监听小程序有版本更新事件。客户端主动触发下载(无需开发者触发),下载成功后回调

        UpdateManager.onUpdateFailed(function callback)
                 监听小程序更新失败事件。小程序有新版本,客户端主动触发下载(无需开发者触发),下载失败(可能是网络原因          等)后回调

Tips:
(1)微信开发者工具上可以通过「编译模式」下的「下次编译模拟更新」开关来调试
(2)小程序开发版/体验版没有「版本」概念,所以无法在开发版/体验版上测试更版本更新情况

例如:
index.js/app.vue

onLoad() {
    if (wx.canIUse("getUpdateManager")) {
      const updateManager = wx.getUpdateManager();
      updateManager.onCheckForUpdate(function(res) {
        // console.log(res.hasUpdate);
        // 请求完新版本信息的回调
        if (res.hasUpdate) {
          updateManager.onUpdateReady(function() {
            wx.showModal({
              title: "更新提示",
              content: "新版本已经准备好,是否重启应用?",
              success(res) {
                if (res.confirm) {
                  // 新的版本已经下载好,调用 applyUpdate 应用新版本并重启
                  updateManager.applyUpdate();
                }
              }
            });
          });
          updateManager.onUpdateFailed(function() {
            // 新的版本下载失败
            wx.showModal({
              title: "已经有新版本了哟~",
              content: "新版本已经上线啦~,请您删除当前小程序,重新搜索打开哟~"
            });
          });
        }
      });
    } else {
      wx.showModal({
        title: "提示",
        content:
          "当前微信版本过低,无法使用该功能,请升级到最新微信版本后重试。"
      });
    }
  }

 

你可能感兴趣的:(机制原理,小程序)