背景:
湖濱網站建設公司創新互聯公司,湖濱網站設計制作,有大型網站制作公司豐富經驗。已為湖濱上1000家提供企業網站建設服務。企業網站搭建\成都外貿網站制作要多少錢,請找那個售后服務好的湖濱做網站的公司定做!
隨著業務的增加,我們服務器需要計算大量的用戶數據,導致用戶跟客服反應頁面不能正常展示。反饋給開發后,我們一看,是服務器異常的錯誤。So,產品想看下我們到底有多少用戶頁面不能正常展示?
方案:
技術方案
因為業務龐大,所以我們不可能區在每個頁面加上重新加載的邏輯。所以初步考慮使用全局重新加載。
需要解決的問題都有哪些?
實踐的方式如下
第一個問題: 比較好解決,我們基于wx.request已經封裝了為fetch(如果還在用wx.request的項目可以考慮封裝下,好處多多)。基于fetch我們可以用res.statusCode來判斷服務器是否出錯。
第二個問題: 暫且先不說具體的跳轉方式是怎樣的,就跳轉的url這個怎么定義也需要我們來討論下。為什么這么說,因為我們的架構涉及到了分包。分包加載意味著我們的代碼不僅僅是在pages下面,還放在了package下。
基于此,我們在跳轉的時候,url能直接寫成'../serverError/serverError'嗎?在主包下面可以正常跳轉,但是在分包下,路徑是'package/serverError/serverError',這樣跳肯定不行。url應該是根目錄下的路徑,所以'/pages/serverError/serverError'。
路徑確認后,我們可以跳轉了。如果是wx.redirectTo(關閉當前頁面,跳轉到應用內的某個頁面),想象下關閉E跳轉到R,點擊重新加載,再關閉R跳轉到E,這么跳轉路徑復雜,用戶體驗不好,并且options的參數需要逐級傳遞。wx.reLaunch類似。我們用所以我們選擇wx.navigateTo。
第三個問題: 綜合問題二的解釋,跳回到E,我們用wx.navigateBack。
第四個問題: 如果從R用wx.navigateBack回到E的話,肯定會觸發E.onShow()方法。但是有些請求我們除了寫在Page.onShow()里,還有些是寫在Page.onLoad()里的,所以我們必須想辦法調起E.onLoad()。
大家對于getCurrentPages()這個方法肯定不陌生,官方定義是來獲取當前頁面棧,我們一般用它來獲取當前頁面路徑。其實在這個過程中,我們是能拿到當前頁面的實例的,并且實例里面有route(頁面路徑)options(頁面傳遞參數)data(頁面初始參數)以及各種function()等等。
利用previousPageClass()我們可以拿到E的實例,也就可以拿到E.options,當然我們也可以調E.onLoad()。
util.js // 獲取當前路徑 function currentPagePath() { let pageData = getCurrentPages() if (pageData.length >= 1) { let len = pageData.length - 1 let data = pageData[len] return data.route } else { return '' } } // 獲取上個界面的實例 function previousPageClass() { let pageData = getCurrentPages() if (pageData.length >= 2) { let len = pageData.length - 2 let preClass = pageData[len] return preClass } else { return '' } } module.exports = { currentPagePath, previousPageClass }
第五個問題: 基于問題的四的方案,我們可以調E.onLoad(E.options)來將我們的參數回傳回去。
第六個問題: 點擊返回,相當于頁面卸載,也就是執行了R.onUnload(),這個時候我們只需要執行E.onLoad(E.options)這個方法,把options傳過去,以及調用起E.onLoad()就OK了。
但是點擊重新加載,我們是調的wx.navigateBack(),這個方法也會走R.onUnload()。這是時候可能有些苦惱了,我們隱藏掉返回按鈕?發現官方并沒有提供此方法。禁用R.onUnload(),好像也不行。因為R.onUnload()是在點擊重新加載后才執行的,所以我們可以記錄下用戶是否點擊了重新加載的行為。然后我們通過記錄的行為,即便用戶點擊了重新加載,然后觸發了R.onUnload(),我們不去執行E.onLoad(E.options)就OK了。
// pages/serverError/serverError.js import { previousPageClass } from '../../utils/util.js' let isClickReload = false Page({ onLoad: function (options) { isClickReload = false }, onUnload: function () { if(!isClickReload) { this.callbackParams() } }, /** * 點擊事件 */ clickReload: function (e) { isClickReload = true wx.navigateBack() this.callbackParams() }, // 點擊返回,參數回傳 callbackParams: function () { let preOptions = previousPageClass().options previousPageClass().onLoad(preOptions) } })
至此所有問題,基本都已解決。
Demo代碼附上,歡迎參考。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對創新互聯的支持。
文章標題:微信小程序如何實現全局重新加載
網頁地址:http://m.newbst.com/article38/jeihpp.html
成都網站建設公司_創新互聯,為您提供定制網站、建站公司、移動網站建設、網站設計公司、網站維護、網站營銷
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯