微信小程序有新版本時自動更新

原文鏈接:https://blog.csdn.net/xiaobo060/article/details/101521906


如圖症副,當小程序發(fā)布新的版本后店雅,用戶如果之前訪問過該小程序,通過已打開的小程序進入(未手動刪除)贞铣,則會彈出這個提示闹啦,提醒用戶更新新的版本。用戶點擊確定就可以自動重啟更新辕坝,點擊取消則關(guān)閉彈窗窍奋,不再更新。


官方給的示例代碼:

constupdateManager = wx.getUpdateManager()

updateManager.onCheckForUpdate(function(res){

// 請求完新版本信息的回調(diào)

console.log(res.hasUpdate)

})

updateManager.onUpdateReady(function(){

? wx.showModal({

title:'更新提示',

content:'新版本已經(jīng)準備好酱畅,是否重啟應用琳袄?',

? ? success(res) {

if(res.confirm) {

// 新的版本已經(jīng)下載好,調(diào)用 applyUpdate 應用新版本并重啟

? ? ? ? updateManager.applyUpdate()

? ? ? }

? ? }

? })

})

updateManager.onUpdateFailed(function(){

// 新版本下載失敗

})


官方提供的demo中纺酸,只有最基本的更新提示窖逗,并未做異常處理。而且官方也說了這個功能基礎(chǔ)庫 1.9.90 開始支持吁峻,低版本需做兼容處理滑负,那么就需要對著端代碼進行改進了。

另一方面用含,如果當前版本更新有重大調(diào)整矮慕,一定需要用戶更新,那么可以在用戶點擊取消的回調(diào)中給出提示啄骇,并重新進入版本提示流程痴鳄。如下圖,在上邊的更新提示中缸夹,用戶點擊取消痪寻,則彈出下面提示彈窗,用戶點擊確定虽惭,則更新版本橡类,點擊取消,則重新調(diào)用上邊的更新提示芽唇」嘶總之取劫,用戶只有更新了,才能正常訪問小程序(如非必須研侣,建議慎用)谱邪。


改善后的代碼:

//app.js

App({

onLaunch:function(options){

this.autoUpdate()

? },

autoUpdate:function(){

console.log(newDate())

varself=this

// 獲取小程序更新機制兼容

if(wx.canIUse('getUpdateManager')) {

constupdateManager = wx.getUpdateManager()

//1. 檢查小程序是否有新版本發(fā)布

updateManager.onCheckForUpdate(function(res){

// 請求完新版本信息的回調(diào)

if(res.hasUpdate) {

//2. 小程序有新版本,則靜默下載新版本庶诡,做好更新準備

updateManager.onUpdateReady(function(){

console.log(newDate())

? ? ? ? ? ? wx.showModal({

title:'更新提示',

content:'新版本已經(jīng)準備好惦银,是否重啟應用?',

success:function(res){

if(res.confirm) {

//3. 新的版本已經(jīng)下載好末誓,調(diào)用 applyUpdate 應用新版本并重啟

? ? ? ? ? ? ? ? ? updateManager.applyUpdate()

}elseif(res.cancel) {

//如果需要強制更新扯俱,則給出二次彈窗,如果不需要基显,則這里的代碼都可以刪掉了

? ? ? ? ? ? ? ? ? wx.showModal({

title:'溫馨提示~',

content:'本次版本更新涉及到新的功能添加蘸吓,舊版本無法正常訪問的哦~',

success:function(res){

? ? ? ? ? ? ? ? ? ? ? self.autoUpdate()

return;

//第二次提示后,強制更新? ? ? ? ? ? ? ? ? ? ?

if(res.confirm) {

// 新的版本已經(jīng)下載好撩幽,調(diào)用 applyUpdate 應用新版本并重啟

? ? ? ? ? ? ? ? ? ? ? ? updateManager.applyUpdate()

}elseif(res.cancel) {

//重新回到版本更新提示

? ? ? ? ? ? ? ? ? ? ? ? self.autoUpdate()

? ? ? ? ? ? ? ? ? ? ? }

? ? ? ? ? ? ? ? ? ? }

? ? ? ? ? ? ? ? ? })

? ? ? ? ? ? ? ? }

? ? ? ? ? ? ? }

? ? ? ? ? ? })

? ? ? ? ? })

updateManager.onUpdateFailed(function(){

// 新的版本下載失敗

? ? ? ? ? ? wx.showModal({

title:'已經(jīng)有新版本了喲~',

content:'新版本已經(jīng)上線啦~库继,請您刪除當前小程序,重新搜索打開喲~',

? ? ? ? ? ? })

? ? ? ? ? })

? ? ? ? }

? ? ? })

}else{

// 如果希望用戶在最新版本的客戶端上體驗您的小程序窜醉,可以這樣子提示

? ? ? wx.showModal({

title:'提示',

content:'當前微信版本過低宪萄,無法使用該功能,請升級到最新微信版本后重試榨惰。'

? ? ? })

? ? }

? }

})


更新版本的模擬測試:

1. 微信開發(fā)者工具上可以通過「編譯模式」下的「下次編譯模擬更新」開關(guān)來調(diào)試拜英;

2. 小程序開發(fā)版/體驗版沒有「版本」概念,所以無法在開發(fā)版/體驗版上測試更版本更新情況琅催;

對于開發(fā)者工具居凶,可以這樣驗證測試:

點擊編譯模式設(shè)置下拉列表,然后點擊“添加編譯模式”藤抡,在自定義編譯條件彈窗界面侠碧,點擊下次編譯時模擬更新,然后點擊確定缠黍,重新編譯就OK了弄兜。

需要注意的是,這種方式模擬更新一次之后就失效了瓷式,后邊再測試仍需要對這種編譯模式進行重新設(shè)置才可以替饿。

更新提示有延遲?

在開發(fā)者工具上測試驗證的時候贸典,更新提示彈窗在小程序界面加載出來五六秒之后才彈出來视卢,這是由于小程序在檢測到有新版本之后,調(diào)用UpdateManager.onUpdateReady(function callback)進行版本更新監(jiān)聽廊驼,此時客戶端主動觸發(fā)下載(無需開發(fā)者觸發(fā))据过,下載成功后回調(diào)颊埃。也就是說我們上邊的更新提示彈窗是在小程序檢測到新版本并完成新版本下載之后彈出的,所以就有了這幾秒的時間差蝶俱。這樣的話就很有必要進行再次改善了,至少應該在小程序編譯時檢測到有新版本就應該先給出更新提示饥漫,至于新版本下載的準備工作榨呆,可以在用戶點擊確認按鈕之后進行,代碼改造如下:

App({

onLaunch:function(options){

? ? this.autoUpdate()

? },

autoUpdate:function(){

varself= this

// 獲取小程序更新機制兼容

if(wx.canIUse('getUpdateManager')) {

constupdateManager = wx.getUpdateManager()

//1. 檢查小程序是否有新版本發(fā)布

updateManager.onCheckForUpdate(function(res){

// 請求完新版本信息的回調(diào)

if(res.hasUpdate) {

//檢測到新版本庸队,需要更新积蜻,給出提示

? ? ? ? ? wx.showModal({

title:'更新提示',

content:'檢測到新版本,是否下載新版本并重啟小程序彻消?',

success:function(res){

if(res.confirm) {

//2. 用戶確定下載更新小程序竿拆,小程序下載及更新靜默進行

self.downLoadAndUpdate(updateManager)

}elseif(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){

varself=this

? ? wx.showLoading();

//靜默下載更新小程序新版本

updateManager.onUpdateReady(function(){

? ? ? wx.hideLoading()

//新的版本已經(jīng)下載好淹朋,調(diào)用 applyUpdate 應用新版本并重啟

? ? ? updateManager.applyUpdate()

? ? })

updateManager.onUpdateFailed(function(){

// 新的版本下載失敗

? ? ? wx.showModal({

title:'已經(jīng)有新版本了喲~',

content:'新版本已經(jīng)上線啦~笙各,請您刪除當前小程序,重新搜索打開喲~',

? ? ? })

? ? })

? }

})


如上础芍,在檢測到小程序有新版本之后杈抢,就給出彈窗提示用戶下載新版并重啟小程序,用戶點擊確定按鈕后進行小程序新版本的下載和更新者甲。也為了調(diào)用方便春感,將新版本下載及小程序的重啟應用單獨封裝起來。

這樣虏缸,從小程序加載到彈出版本更新彈窗只需要耗費調(diào)用新版本檢測API并返回結(jié)果的時間(開發(fā)者工具測試有2~3秒)鲫懒,雖說還是有一點延遲,但目前也只能這樣了刽辙。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末窥岩,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子宰缤,更是在濱河造成了極大的恐慌颂翼,老刑警劉巖晃洒,帶你破解...
    沈念sama閱讀 216,744評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異朦乏,居然都是意外死亡球及,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,505評論 3 392
  • 文/潘曉璐 我一進店門呻疹,熙熙樓的掌柜王于貴愁眉苦臉地迎上來吃引,“玉大人,你說我怎么就攤上這事刽锤∧鞒撸” “怎么了?”我有些...
    開封第一講書人閱讀 163,105評論 0 353
  • 文/不壞的土叔 我叫張陵并思,是天一觀的道長庐氮。 經(jīng)常有香客問我,道長宋彼,這世上最難降的妖魔是什么弄砍? 我笑而不...
    開封第一講書人閱讀 58,242評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮宙暇,結(jié)果婚禮上输枯,老公的妹妹穿的比我還像新娘。我一直安慰自己占贫,他們只是感情好桃熄,可當我...
    茶點故事閱讀 67,269評論 6 389
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著型奥,像睡著了一般瞳收。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上厢汹,一...
    開封第一講書人閱讀 51,215評論 1 299
  • 那天螟深,我揣著相機與錄音,去河邊找鬼烫葬。 笑死界弧,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的搭综。 我是一名探鬼主播垢箕,決...
    沈念sama閱讀 40,096評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼兑巾!你這毒婦竟也來了条获?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,939評論 0 274
  • 序言:老撾萬榮一對情侶失蹤蒋歌,失蹤者是張志新(化名)和其女友劉穎帅掘,沒想到半個月后委煤,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,354評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡修档,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,573評論 2 333
  • 正文 我和宋清朗相戀三年碧绞,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吱窝。...
    茶點故事閱讀 39,745評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡头遭,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出癣诱,到底是詐尸還是另有隱情,我是刑警寧澤袜香,帶...
    沈念sama閱讀 35,448評論 5 344
  • 正文 年R本政府宣布撕予,位于F島的核電站,受9級特大地震影響蜈首,放射性物質(zhì)發(fā)生泄漏实抡。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,048評論 3 327
  • 文/蒙蒙 一欢策、第九天 我趴在偏房一處隱蔽的房頂上張望吆寨。 院中可真熱鬧,春花似錦踩寇、人聲如沸啄清。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,683評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽辣卒。三九已至瞭亮,卻和暖如春灾杰,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背睁本。 一陣腳步聲響...
    開封第一講書人閱讀 32,838評論 1 269
  • 我被黑心中介騙來泰國打工场靴, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留啡莉,地道東北人。 一個月前我還...
    沈念sama閱讀 47,776評論 2 369
  • 正文 我出身青樓旨剥,卻偏偏與公主長得像咧欣,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子泞边,可洞房花燭夜當晚...
    茶點故事閱讀 44,652評論 2 354

推薦閱讀更多精彩內(nèi)容