欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

小程序響應(yīng)速度慢怎么辦

這篇文章主要介紹小程序響應(yīng)速度慢怎么辦,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!

為杞縣等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計制作服務(wù),及杞縣網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為做網(wǎng)站、成都網(wǎng)站建設(shè)、杞縣網(wǎng)站設(shè)計,以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!

目的:

解決小程序響應(yīng)速度慢,用戶體驗差的問題。

優(yōu)化方法如下:

1、提高頁面加載速度

在小程序這個環(huán)境下,怎樣提高頁面加載速度呢? 這個問題很大,我把問題具體一下,如何縮短從用戶點擊某個鏈接,到打開新頁面的這段時間? 這里拋一個核心關(guān)鍵點:

從頁面響應(yīng)用戶點擊行為,開始跳轉(zhuǎn),到新頁面onload事件觸發(fā),存在一個延遲,這個延遲大概在100-300ms之間(安卓響應(yīng)比ios慢些)。

這個延遲說短不短,我們可以利用這段時間,預(yù)先發(fā)起新頁面所需要的網(wǎng)絡(luò)請求。這樣一來,就節(jié)省了100-300ms(或者一個網(wǎng)絡(luò)請求的時間)。

知道有這個gap后,代碼如何實現(xiàn)呢?

說白了,就是實現(xiàn)一個在A頁面預(yù)加載B頁面數(shù)據(jù)的功能。但而這種跨頁面的調(diào)用,很容易把邏輯搞復(fù)雜,將不同頁面的邏輯耦合在一起。所以,我們希望將預(yù)加載的邏輯隱藏于無形中,不增加任何的頁面間耦合,以及開發(fā)復(fù)雜度。

下面以騰訊視頻小程序為例,講解下技術(shù)實現(xiàn)。

小程序首頁:

小程序響應(yīng)速度慢怎么辦

當(dāng)用戶點擊海報圖后,會執(zhí)行以下代碼(就一行):

小程序響應(yīng)速度慢怎么辦

接下來程序會加載播放頁:

小程序響應(yīng)速度慢怎么辦

播放頁主要代碼:

小程序響應(yīng)速度慢怎么辦

可以看到,不管是外部頁面的調(diào)用還是實際邏輯的實現(xiàn)都非常簡潔。在第二個頁面中,我們擴(kuò)展了Page的生命周期函數(shù),增加了onNavigate方法。該方法在頁面即將被創(chuàng)建但還沒開始創(chuàng)建的時候執(zhí)行。

老司機(jī)也許會發(fā)現(xiàn)這里有點蹊蹺。在首頁點擊的時候,播放頁根本就沒有創(chuàng)建,對象都不存在,怎么訪問到里面的方法呢?

這里就要說下微信的頁面機(jī)制。

在小程序啟動時,會把所有調(diào)用Page()方法的object存在一個隊列里(如下圖)。每次頁面訪問的時候,微信會重新創(chuàng)建一個新的對象實例(實際上就是深拷貝)。

也就是說,在A頁面在執(zhí)行點擊響應(yīng)事件的時候,B頁面的實例還沒創(chuàng)建,這時候調(diào)用的onNavigate方法,實際上是Page對象的原型(小程序啟動時候創(chuàng)建的那個)

而接下來馬上要被創(chuàng)建的B頁面,又是另外一個object。所以,在onNavigate和onLoad方法中,this指針指的不是同一個對象,不能把臨時數(shù)據(jù)存儲在當(dāng)前object身上。因此我們封裝了一對全局的緩存方法,$put()和$take()。

小程序響應(yīng)速度慢怎么辦

為了通用性,Page上用到的公共的方法,比如$route、$put、$take都定義在了一個Page的基類里面?;愡€同時保存了所有頁面的list,這樣就可以做到根據(jù)頁面名調(diào)用具體頁面的onNavigate方法。 當(dāng)然,并不是每個頁面都需要實現(xiàn)onNavigate方法,對于沒有定義onNavigate方法的,$route函數(shù)會跳過預(yù)加載環(huán)節(jié),直接跳轉(zhuǎn)頁面。所以對于開發(fā)者來說,不需要關(guān)心別的頁面實現(xiàn)了什么,對外看來完全透明。

2、用戶行為預(yù)測

在上面的例子中,我們實現(xiàn)了用戶主動點擊頁面,提前加載下一頁面數(shù)據(jù)的方法。而在某些場景下,用戶的行為可以預(yù)測,我們可以在用戶還沒點擊的時候就預(yù)加載下個頁面的數(shù)據(jù)。讓下個頁面秒開,進(jìn)一步提升體驗的流暢性。

繼續(xù)以騰訊視頻小程序為例,主界面分為3個頁卡(大部分小程序都會這么設(shè)計),通過簡單的數(shù)據(jù)分析,發(fā)現(xiàn)進(jìn)入首頁的用戶有50%會訪問第二個頁卡。所以預(yù)加載第二個頁卡的數(shù)據(jù)可以很大程度提高用戶下個點擊頁面的打開速度。

同樣,先看看代碼實現(xiàn)。 首頁預(yù)加載頻道頁的姿勢:

小程序響應(yīng)速度慢怎么辦

頻道頁的實現(xiàn)方法:

小程序響應(yīng)速度慢怎么辦

跟第一個例子類似,這里定義了一個$preLoad()方法,同時給Page擴(kuò)展了一個onPreload事件。頁面調(diào)用$preLoad()后,基類會自動找到該頁面對應(yīng)的onPreload函數(shù),通知頁面執(zhí)行預(yù)加載操作。 跟第一個例子不同,這里預(yù)加載的數(shù)據(jù)會保存在storage內(nèi),因為用戶不一定會馬上訪問頁面,而把數(shù)據(jù)存在全局變量會增加小程序占用的內(nèi)存。微信會毫不猶豫的把內(nèi)存占用過大的小程序給殺掉。

也許對于大部分有app開發(fā)經(jīng)驗的同學(xué)來說,更普遍的做法是先讓頁面展示上次緩存的數(shù)據(jù),再實時拉取新數(shù)據(jù),然后刷新頁面。這個方法在小程序上也許體驗并不太好,原因是小程序的性能以及頁面渲染速度都不如原生app。將一個大的data傳輸給UI層,是一個很重的操作。因此不建議采用這種方法。

3、減少默認(rèn)data的大小

剛剛說到,頁面打開一個新頁面時微信會深拷貝一個page對象,因此,應(yīng)該盡量減少默認(rèn)data的大小,以及減少對象內(nèi)的自定義屬性。有圖有真相:

小程序響應(yīng)速度慢怎么辦

以一個100個屬性的data對象為測試用例,在iphone6上,頁面的創(chuàng)建時間會因此增加150ms。

4、組件化方案

微信沒有提供小程序的組件化方案(相信一定在實現(xiàn)中)。但開談不說組件化,寫再多代碼也枉然。這里演示一個簡單的組件化實現(xiàn)。

以騰訊視頻播放頁為例,頁面定義如下:

小程序響應(yīng)速度慢怎么辦

其中,P()函數(shù)是自定義的基類。這是一個非常有用的東西,可以把所有通用的邏輯都寫在基類里面,包括pv統(tǒng)計,來源統(tǒng)計,擴(kuò)展生命周期函數(shù),實現(xiàn)組件化等。

函數(shù)第一個參數(shù)是頁面名稱,作為頁面的key。第二個是page對象,其中擴(kuò)展了一個comps數(shù)組,里面就是所有要加載的組件。

以播放器組件/comps/player/index.js為例:

小程序響應(yīng)速度慢怎么辦

組件的定義跟一個普通Page對象一模一樣,有data屬性,onLoad、onShow等事件,也有頁面響應(yīng)的回調(diào)方法。wxml模板里定義的事件和js事件一一對應(yīng)。

基類做的事情,就是把這些組件對象的屬性和方法復(fù)制到Page對象上(淺拷貝)。其中data屬性會merge到一起。而微信預(yù)定義的生命周期函數(shù)(包括自己擴(kuò)展的),則封裝成隊列按序執(zhí)行。比如當(dāng)系統(tǒng)調(diào)用onLoad方法時,實際上是執(zhí)行了所有組件的onLoad方法,最后再執(zhí)行Page的onLoad。

以上是代碼部分,至于wxml模板和wxss部分,就要手工import過去了。

wxml:

小程序響應(yīng)速度慢怎么辦

wxss:

小程序響應(yīng)速度慢怎么辦

5、其他

雖然小程序已經(jīng)足夠小巧,但啟動速度還是有那么2-3秒,無法做到秒開。樓主嘗試對小程序的啟動時間做優(yōu)化,但沒有找到多少有價值的優(yōu)化點。單個頁面的初始化只需要1-2ms。也許大部分時間消耗在了微信跟服務(wù)器端通信的過程中。

所幸,騰訊提供了一個可以自主進(jìn)行服務(wù)器性能測試的環(huán)境,用戶只需要填寫域名和簡單的幾個參數(shù)就可以獲知自己的服務(wù)器性能情況,目前在騰訊WeTest平臺可以免費使用。

以上是“小程序響應(yīng)速度慢怎么辦”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

本文題目:小程序響應(yīng)速度慢怎么辦
文章來源:http://aaarwkj.com/article26/gjddcg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、網(wǎng)站營銷響應(yīng)式網(wǎng)站、ChatGPT、App設(shè)計云服務(wù)器

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)
日本日韩一区二区国产| 亚洲成年人黄色在线观看| 国内校园性猛交视频网站| 亚洲精品偷拍在线观看| 九色国产一区二区三区| 人妻大乳一区二区三区| 国产超大超粗超爽视频| 色婷婷一区二区三区影片| 国产激情福利一区二区| 日韩黄色一级免费在线观看| 亚洲最大av免费在线看| 日韩精品极品在线视频观看免费| 国产欧美日韩一区二区三区不卡| 国产成人精品久久性色av| 亚洲av一区二区三区网站| 另类欧美亚洲中文在线综合| 爽妇网亚洲一区二区三区| 精品色妇熟妇丰满人妻5| 亚洲精品成人中文字幕| 国产欧美色日韩综合在线| 国产一级性生活高清在线| 91免费在线观看国产精品| 久久亚洲中文字幕精品一区四区| 亚洲免费av第一区第二区| 亚洲熟女熟妇另类中文| 色婷婷亚洲一区二区三区| 亚洲国产精品97视频| 亚洲精品一区二区三区三州| 丰满少妇一级淫片在线播放| 尤物视频网站在线观看| 欧美一级特黄大片做受另类| 国产av一区二区三区野战| 最新日韩人妻中文字幕一区| 免费观看国内性生活大片| 韩国理伦三级做爰观看| 亚洲一区二区三区四区国产| 日韩在线一区二区视频| 精品三级黄色国产片| 人妻内射一区二区在线视| 精品人妻一区二区三区| 中文字幕国产精品一二区|