• 微信小程序判断当前是否最新版本并且更新


    在app.js中添加以下代码,并且在onLaunch中调用,每次更新后会弹出更新的提示框,点击确定即可更新为最新版本

      autoUpdate: function() {
        let _this = this
        // 获取小程序更新机制的兼容,由于更新的功能基础库要1.9.90以上版本才支持,所以此处要做低版本的兼容处理
        if (wx.canIUse('getUpdateManager')) {
          // wx.getUpdateManager接口,可以获知是否有新版本的小程序、新版本是否下载好以及应用新版本的能力,会返回一个UpdateManager实例
          const updateManager = wx.getUpdateManager()
          // 检查小程序是否有新版本发布,onCheckForUpdate:当小程序向后台请求完新版本信息,会通知这个版本告知检查结果
          updateManager.onCheckForUpdate(function(res) {
            // 请求完新版本信息的回调
            if (res.hasUpdate) {
              // 检测到新版本,需要更新,给出提示
              wx.showModal({
                title: '更新提示',
                content: '检测到新版本,是否下载新版本并重启小程序',
                success: function(res) {
                  if (res.confirm) {
                    // 用户确定更新小程序,小程序下载和更新静默进行
                    _this.downLoadAndUpdate(updateManager)
                  } else if (res.cancel) {
                    // 若用户点击了取消按钮,二次弹窗,强制更新,如果用户选择取消后不需要进行任何操作,则以下内容可忽略
                    wx.showModal({
                      title: '提示',
                      content:
                        '本次版本更新涉及到新功能的添加,旧版本将无法正常使用',
                      showCancel: false, // 隐藏取消按钮
                      confirmText: '确认更新', // 只保留更新按钮
                      success: function(res) {
                        if (res.confirm) {
                          // 下载新版本,重启应用
                          _this.downLoadAndUpdate(updateManager)
                        }
                      }
                    })
                  }
                }
              })
            }
          })
        } else {
          // 在最新版本客户端上体验小程序
          wx.showModal({
            title: '提示',
            content: '当前微信版本过低,无法使用该功能,请升级到最新微信版本后重试'
          })
        }
      },
      // 下载小程序最新版本并重启
      downLoadAndUpdate: function(updateManager) {
        wx.showLoading()
        // 静默下载更新小程序新版本,onUpdateReady:当新版本下载完成回调
        updateManager.onUpdateReady(function() {
          wx.hideLoading()
          // applyUpdate:强制当前小程序应用上新版本并重启
          updateManager.applyUpdate()
        })
        // onUpdateFailed:当新版本下载失败回调
        updateManager.onUpdateFailed(function() {
          // 下载新版本失败
          wx.showModal({
            title: '已有新版本',
            content: '新版本已经上线了,请删除当前小程序,重新搜索打开'
          })
        })
      }
    

      转载自https://juejin.cn/post/6844904007173931021

  • 相关阅读:
    OCS 2007 R2单机测试虚拟环境的搭建(windows server 2008 R2 x64)
    Linq的概念解析
    WCF Data Service与net.tcp承载分析
    codeplex上20个有意思的WPF程序
    各种SmartPhone上的跨平台开源框架的总结
    新开发Apple Store上软件的实施步骤
    VSTO应用程序中加入键盘钩子
    绝非偶然 苹果iPhone领先5年背后的迷思 【推荐】
    Windows上安装Mac OS虚拟机
    Visual Studio 远程调试的步骤
  • 原文地址:https://www.cnblogs.com/sisxxw/p/15174660.html
Copyright © 2020-2023  润新知