欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

微信小程序-强制手机端更新

程序员文章站 2022-06-28 23:52:13
小程序的更新机制 开发者在管理后台发布新版本的小程序之后,如果某个用户本地有小程序的历史版本,此时打开的可能还是旧版本。微信客户端会有若干个时机去检查本地缓存的小程序有没有更新版本,如果有则会静默更新到新版本。总的来说,开发者在后台发布新版本之后,无法立刻影响到所有现网用户,但最差情况下,也在发布之 ......

小程序的更新机制

开发者在管理后台发布新版本的小程序之后,如果某个用户本地有小程序的历史版本,此时打开的可能还是旧版本。微信客户端会有若干个时机去检查本地缓存的小程序有没有更新版本,如果有则会静默更新到新版本。总的来说,开发者在后台发布新版本之后,无法立刻影响到所有现网用户,但最差情况下,也在发布之后 24 小时之内下发新版本信息到用户。用户下次打开时会先更新最新版本再打开。

启动时更新

小程序每次冷启动时,都会检查是否有更新版本,如果发现有新版本,将会异步下载新版本的代码包,并同时用客户端本地的包进行启动,即新版本的小程序需要等下一次冷启动才会应用上。

关于冷/热启动及前/后台的概念,请参照小程序文档

可以通过wx.getupdsatemanagerapi来强制用户在启动时更新新版本。

        wx.showloading({
            title: '加载中..',
            mask: true
        })

        const updatemanager = wx.getupdatemanager()

        updatemanager.oncheckforupdate(function (res) {
            // 请求完新版本信息的回调
            console.log('是否有新版本: ', + res.hasupdate)
            if (!res.hasupdate) {
                wx.hideloading()
            } 
        })

        updatemanager.onupdateready(function () {
            wx.hideloading()
            wx.showmodal({
                title: '更新提示',
                content: '新版本已经准备好,是否重启应用?',
                showcancel: false,
                success: function (res) {
                    if (res.confirm) {
                        // 新的版本已经下载好,调用 applyupdate 应用新版本并重启
                        updatemanager.applyupdate()
                    }
                }
            })
        })

        updatemanager.onupdatefailed(function () {
            wx.hideloading();
            wx.showmodal({
                title: '提示',
                content: '检查到有新版本,但下载失败,请检查网络后重试',
                showcancel: false
            })
        })

        settimeout(wx.hideloading, 5000)

由于oncheckforupdate在检查新版本的时候会存在一定的延迟(在开发工具上大概4秒左右),为防止在检查新版本过程中用户触发操作跳出首页,添加了一个wx.showloading进行遮盖。

需要注意,上面的代码更新到新版本后也是不会立即生效的,所以还是需要用户进行一次冷启动。

参考: