亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

微信小程序如何實現全局重新加載

2019-11-19 11:23:49
字體:
來源:轉載
供稿:網友

背景:

隨著業務的增加,我們服務器需要計算大量的用戶數據,導致用戶跟客服反應頁面不能正常展示。反饋給開發后,我們一看,是服務器異常的錯誤。So,產品想看下我們到底有多少用戶頁面不能正常展示?

方案:

  1. 后端人員直接在阿里云后臺去查哪些接口異常
  2. 前端做一個服務器報錯頁,這樣產品在小程序后臺能看到這個頁面的PV,UV

技術方案

因為業務龐大,所以我們不可能區在每個頁面加上重新加載的邏輯。所以初步考慮使用全局重新加載。

需要解決的問題都有哪些?

  1. 首先我們要有網絡請求失敗的全局控制權(要不然就需要在每個頁面處理失敗的情況)
  2. 需要定義好網絡失敗后是如何跳轉到重載頁(R)的(用wx.redirectTo,wx.reLaunch還是其他)
  3. 點擊錯誤頁的“重新加載”,如何返回或跳轉到出錯頁(E)(用wx.redirectTo,wx.reLaunch還是其他)
  4. 跳轉到出錯頁后,如何重新加載數據(把所有請求都放在Page.onShow()里面?)
  5. 那如果從出錯頁的上個界面(P)傳到出錯頁(E)options,那重載頁(R)又將如何處理?
  6. 點擊重新加載跟返回,我們希望效果效果一樣,又該如何操作?

實踐的方式如下

第一個問題: 比較好解決,我們基于wx.request已經封裝了為fetch(如果還在用wx.request的項目可以考慮封裝下,好處多多)?;趂etch我們可以用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.jsimport { previousPageClass } from '../../utils/util.js'let isClickReload = falsePage({ 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代碼附上,歡迎參考。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩在线精品一区| 日韩精品极品在线观看播放免费视频| 亚洲成人黄色网| 国产日本欧美在线观看| 精品亚洲一区二区三区| 亚洲视频一区二区三区| 亚洲二区在线播放视频| 亚洲国产天堂久久综合网| 亚洲综合在线中文字幕| 久久久www成人免费精品| 国产精品av在线播放| 国产精品一区久久久| 96国产粉嫩美女| 亚洲a一级视频| 国产精品久久久久久久久久久不卡| 亚洲午夜国产成人av电影男同| 国内外成人免费激情在线视频网站| 亚洲va欧美va在线观看| 亚洲欧洲日韩国产| 欧美激情手机在线视频| 91国产一区在线| 91在线免费网站| 66m—66摸成人免费视频| 欧美一区深夜视频| 亚洲大胆人体在线| 国产一区在线播放| 日韩在线观看免费| 亚洲国产又黄又爽女人高潮的| 精品在线小视频| 欧美国产日韩在线| 亚洲欧美日韩中文在线制服| 亚洲欧美日韩视频一区| 日韩小视频网址| 日本免费久久高清视频| 久久久久久成人精品| 成人在线视频网站| 亚洲第一页自拍| 欧美怡红院视频一区二区三区| 亚洲人成电影网站色| 国产99在线|中文| 亚洲人成网站在线播| 国产91亚洲精品| 色综合91久久精品中文字幕| 69久久夜色精品国产69| 亚洲一区美女视频在线观看免费| 海角国产乱辈乱精品视频| 亚洲欧洲日韩国产| 97精品久久久中文字幕免费| 亚洲国产精品电影在线观看| 日韩欧美精品在线观看| 亚洲激情视频网站| 精品视频久久久| 欧美激情精品久久久久久| 国产欧美一区二区三区在线| 亚洲黄页网在线观看| 亚洲欧美精品伊人久久| 中文日韩电影网站| 日韩av不卡电影| 国产视频999| 国产综合视频在线观看| 亚洲欧美激情精品一区二区| 国产精品久久久久aaaa九色| 最好看的2019年中文视频| 激情懂色av一区av二区av| 原创国产精品91| 国产一区二区丝袜| 最近中文字幕2019免费| 91精品久久久久久久久中文字幕| 久久亚洲影音av资源网| 国产精品青青在线观看爽香蕉| 亚洲综合大片69999| 日韩av综合中文字幕| 日韩精品中文字幕视频在线| 国产精品激情av在线播放| 国产成人综合精品在线| 91视频免费网站| 国产成人av在线| 日韩精品极品在线观看播放免费视频| 精品国产1区2区| 中文字幕一区电影| 国产区亚洲区欧美区| 中文字幕精品一区久久久久| 伊人伊成久久人综合网小说| 亚洲a区在线视频| zzjj国产精品一区二区| 中文字幕日韩av电影| 国产97色在线|日韩| 自拍偷拍亚洲精品| 亚洲精品99久久久久中文字幕| 欧美成人免费小视频| 精品国产欧美成人夜夜嗨| 中文字幕视频一区二区在线有码| 亚洲网站视频福利| 国产欧美亚洲精品| 国产伦精品一区二区三区精品视频| 久久这里只有精品视频首页| 91欧美精品成人综合在线观看| 欧美国产高跟鞋裸体秀xxxhd| 日韩美女视频在线观看| 精品自拍视频在线观看| 国产一区二区三区免费视频| 97视频在线观看免费高清完整版在线观看| 91av在线看| 欧美日韩国产在线播放| 欧美日韩国产综合新一区| 在线观看视频99| 欧美综合第一页| 欧美国产精品va在线观看| 欧美中文字幕精品| 国产欧美精品在线播放| 日本精品视频在线观看| 久久久久久久97| 亚洲欧洲日韩国产| 久久亚洲精品一区二区| 国产精品免费电影| 97视频在线观看播放| 国产精品久久久av久久久| 国产免费一区二区三区在线观看| 清纯唯美亚洲综合| 国产精品青草久久久久福利99| 久久亚洲一区二区三区四区五区高| 成人免费淫片aa视频免费| 精品视频在线观看日韩| 国产日韩亚洲欧美| 国产精品久久久久久久久影视| 国产日韩欧美中文在线播放| 国产精品自拍偷拍视频| 国产精品日日摸夜夜添夜夜av| 91精品久久久久久久久不口人| 在线视频欧美日韩精品| 视频在线一区二区| 揄拍成人国产精品视频| 亚洲成人精品久久久| 日韩一区二区三区国产| 日韩精品在线第一页| xxav国产精品美女主播| 亚洲码在线观看| 亚洲嫩模很污视频| 中文字幕亚洲激情| 亚洲小视频在线观看| 4444欧美成人kkkk| 久久黄色av网站| 色狠狠久久aa北条麻妃| 亚洲精品自在久久| 日韩精品极品在线观看| 亚洲人成啪啪网站| 日本高清+成人网在线观看| 久久香蕉精品香蕉| 久久99亚洲精品| 久久99久久99精品免观看粉嫩| 91av视频在线免费观看| 成人免费视频97| 欧美黑人xxxⅹ高潮交| 亚洲激情免费观看| 亚洲片av在线| 91精品久久久久久久久青青| 欧美激情乱人伦一区| 97精品一区二区视频在线观看| 久久影院资源站| 亚洲激情小视频| 日韩欧美在线视频免费观看| 国产精品福利无圣光在线一区| 久久影视电视剧免费网站清宫辞电视| 久久影院在线观看|