小程序检测新版本并更新到最新版本

检测小程序是否有新版本发布,主要用的的api有:
onCheckForUpdate 监听向微信后台请求检查更新结果事件。微信在小程序每次启动(包括热启动)时自动检查更新,不需由开发者主动触发。
onUpdateReady 监听小程序有版本更新事件,客户端主动触发下载(无需开发者触发),下载成功后回调。
applyUpdate 强制小程序重启并使用新版本。在小程序新版本下载完成后(即收到 onUpdateReady 回调)调用。
onUpdateFailed 监听小程序更新失败事件。小程序有新版本,客户端主动触发下载(无需开发者触发),下载失败(可能是网络原因等)后回调。
一般是在一进入小程序中就需要检测是否有新版本,因而将这部分放置在app.js中的onLaunch启动回调函数中,但需要注意:小程序开发版/体验版没有「版本」概念,所以无法在开发版/体验版上测试更版本更新情况。下面是完整更新代码:
onLaunch() {
this.autoUpdate()
},

autoUpdate: function() {
var self = this
// 获取小程序更新的兼容
if (wx.canIUse(‘getUpdateManager’)) {
const updateManager = wx.getUpdateManager()
//1. 检查是否有新版本发布
updateManager.onCheckForUpdate(function(res) {
// 请求完新版本信息的回调
if (res.hasUpdate) {
//检测有新版本,需要更新并给出提示
wx.showModal({
title: ‘更新提示’,
content: ‘检测到有新版本,是否下载新版本并重启小程序?’,
success: function(res) {
if (res.confirm) {
//2. 用户确定下载更新小程序,小程序下载及更新静默进行
self.downLoadAndUpdate(updateManager)
} else if (res.cancel) {
//用户点击取消按钮的处理,如需要强制更新,给出二次弹窗,如不需要,这里的代码都可以删掉
wx.showModal({
title: ‘温馨提示’,
content: ‘本次版本更新涉及到新的功能添加,旧版本无法正常访问哟’,
showCancel:false,//隐藏取消按钮
confirmText:“确定更新”,//只保留确定更新按钮
success: function(res) {
if (res.confirm) {
//下载新版本并更新
self.downLoadAndUpdate(updateManager)
}
}
})
}
}
})
}
})
} else {
// 如果希望用户在最新版本的客户端上体验您的小程序
wx.showModal({
title: ‘温馨提示’,
content: ‘当前微信版本过低,请升级到最新微信版本后重试。’
})
}
},

/**

  • 下载小程序新版本并重启应用
    */
    downLoadAndUpdate: function (updateManager){
    var self=this
    wx.showLoading();
    //静默下载更新小程序新版本
    updateManager.onUpdateReady(function () {
    wx.hideLoading()
    //新的版本已经下载好,调用 applyUpdate 应用新版本并重启
    updateManager.applyUpdate()
    })
    updateManager.onUpdateFailed(function () {
    // 新的版本下载失败
    wx.showModal({
    title: ‘下载失败提示’,
    content: ‘下载新版本失败,请您删除当前小程序,重新搜索打开~’,
    })
    })
    },

你可能感兴趣的:(小程序,小程序)