微信小程序检测版本更新

本文介绍了在原生小程序和uni-app中实现版本更新的代码示例。通过wx.canIUse检查更新功能,使用getUpdateManager获取更新管理器,并监听onCheckForUpdate、onUpdateReady和onUpdateFailed事件来处理新版本的检查、下载成功和失败情况。在用户确认更新后,应用新版本并重启应用。
摘要由CSDN通过智能技术生成

原生小程序

在app.js中写如下代码
onLaunch() {
  if (wx.canIUse('getUpdateManager')) {
    const updateManager = wx.getUpdateManager()
    updateManager.onCheckForUpdate(function (res) {
      console.log('onCheckForUpdate====', res)
      // 请求完新版本信息的回调
      if (res.hasUpdate) {
        console.log('res.hasUpdate====')
        updateManager.onUpdateReady(function () {
          wx.showModal({
            title: '更新提示',
            content: '新版本已经准备好,是否重启应用?',
            success: function (res) {
              console.log('success====', res)
              // res: {errMsg: "showModal: ok", cancel: false, confirm: true}
              if (res.confirm) {
                // 新的版本已经下载好,调用 applyUpdate 应用新版本并重启
                updateManager.applyUpdate()
              }
            }
          })
        })
        updateManager.onUpdateFailed(function () {
          // 新的版本下载失败
          wx.showModal({
            title: '已经有新版本了哟~',
            content: '新版本已经上线啦~,请您删除当前小程序,重新搜索打开哟~'
          })
        })
      }
    })
  }
}

uniapp方式

在App.vue里面
onShow: function() {
	console.log('App Show')
	// 版本更新
	if(uni.canIUse('getUpdateManager')) {
		// 判断当前微信版本是够支持版本更新
		const updateManager = uni.getUpdateManager()
		updateManager.onCheckForUpdate(function(res){
			if(res.hasUpdate) {
				// 请求完新版本信息的回调
				updateManager.onUpdateReady(function(){
					uni.showModal({
						title: '更新提示',
						content: '新版本已经准备好,是否重启应用?',
						success(res) {
							if(res.confirm) {
								// 新的版本已经下载好,调用 applyUpdate 应用新版本并重启
								updateManager.applyUpdate()
							}
						}
					})
				})
				updateManager.onUpdateFailed(function() {
					uni.showModal({
						// 新版本下载失败
						title: '已经有新版本了~',
						content: '新版本已经上线了,请您删除当前小程序,重新搜索打开体验新版本'
					})
				})
			}
		})
	}
},
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值