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

本文介绍了如何在微信小程序中检测新版本并实现自动下载,包括onCheckForUpdate和onUpdateReadyAPI的使用,以及如何处理下载成功和失败的情况。开发者需注意开发版和体验版的限制。
摘要由CSDN通过智能技术生成

检测小程序是否有新版本发布,主要用的的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: ‘下载新版本失败,请您删除当前小程序,重新搜索打开~’,
    })
    })
    },
  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值