這篇文章主要介紹小程序加載快慢的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
創(chuàng)新互聯(lián)建站是一家集網(wǎng)站建設(shè),龍圩企業(yè)網(wǎng)站建設(shè),龍圩品牌網(wǎng)站建設(shè),網(wǎng)站定制,龍圩網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營(yíng)銷,網(wǎng)絡(luò)優(yōu)化,龍圩網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競(jìng)爭(zhēng)力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長(zhǎng)自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。首先,先從網(wǎng)絡(luò)請(qǐng)求network說(shuō)起:
這里基本不關(guān)前端的事情,但是這也是優(yōu)化小程序的一大重點(diǎn),后端響應(yīng)我們請(qǐng)求數(shù)據(jù)的速度影響了整個(gè)頁(yè)面的速度,所以,把它拿到第一位
請(qǐng)求超過(guò)300ms就已經(jīng)算是慢了,所以會(huì)影響總體速度。
建議:叫后端優(yōu)化接口,加快響應(yīng)速度。
還有,盡量減少無(wú)謂的請(qǐng)求,將數(shù)據(jù)合并到一個(gè)接口上,這樣可以方便操作,又可以節(jié)約資源,(前提不被后端責(zé)罵)
第二:圖片
圖片的話,對(duì)越用戶上傳的圖片的大小驗(yàn)證一下,大于500K的拒絕就好了,盡量經(jīng)過(guò)壓縮在上傳服務(wù)器,如果文中含有大量的圖片的,盡量使用base64,轉(zhuǎn)換一下,可以減少點(diǎn)資源,
多圖片的情況況下,好做一個(gè)懶加載技術(shù)。。。把一些體積較大的圖片資源改為使用線上資源。具體做法是將素材先上傳到 cdn,然后在小程序中直接使用線上圖片地址。
不懂得如何壓縮大小的可以看看這個(gè)https://blog.csdn.net/Young_Gao/article/details/88183442現(xiàn)成的
第三:控制小程序包 的大小 減小資源包體積
精簡(jiǎn)第三方依賴 盡量少用第三方包,第三方的方有的會(huì)引用比較大的模塊,盡量節(jié)約吧,減少不必要的代碼...包括一些注釋掉的,它好像也會(huì)打包進(jìn)去,所以好就刪除吧,
第四:關(guān)于調(diào)用第三方接口的問(wèn)題
調(diào)用了第三方的接口速度會(huì)很慢——例如調(diào)用了騰訊的獲取定位,有時(shí)候需要1秒才能響應(yīng),如果公司內(nèi)部有自己的接口和算法,還是調(diào)用自己的吧,哪怕是騰訊的api有時(shí)候他響應(yīng)的速度也會(huì)超過(guò)300ms,盡量少用
第五:關(guān)于setData
5.1. 頻繁的去 setData
在我們分析過(guò)的一些案例里,部分小程序會(huì)非常頻繁(毫秒級(jí))的去setData
,其導(dǎo)致了兩個(gè)后果:
Android 下用戶在滑動(dòng)時(shí)會(huì)感覺(jué)到卡頓,操作反饋延遲嚴(yán)重,因?yàn)?JS 線程一直在編譯執(zhí)行渲染,未能及時(shí)將用戶操作事件傳遞到邏輯層,邏輯層亦無(wú)法及時(shí)將操作處理結(jié)果及時(shí)傳遞到視圖層;
渲染有出現(xiàn)延時(shí),由于 WebView 的 JS 線程一直處于忙碌狀態(tài),邏輯層到頁(yè)面層的通信耗時(shí)上升,視圖層收到的數(shù)據(jù)消息時(shí)距離發(fā)出時(shí)間已經(jīng)過(guò)去了幾百毫秒,渲染的結(jié)果并不實(shí)時(shí);
5.2. 每次 setData 都傳遞大量新數(shù)據(jù)
由setData
的底層實(shí)現(xiàn)可知,我們的數(shù)據(jù)傳輸實(shí)際是一次evaluateJavascript
腳本過(guò)程,當(dāng)數(shù)據(jù)量過(guò)大時(shí)會(huì)增加腳本的編譯執(zhí)行時(shí)間,占用 WebView JS 線程,
5.3. 后臺(tái)態(tài)頁(yè)面進(jìn)行 setData
當(dāng)頁(yè)面進(jìn)入后臺(tái)態(tài)(用戶不可見(jiàn)),不應(yīng)該繼續(xù)去進(jìn)行setData
,后臺(tái)態(tài)頁(yè)面的渲染用戶是無(wú)法感受的,另外后臺(tái)態(tài)頁(yè)面去setData
也會(huì)搶占前臺(tái)頁(yè)面的執(zhí)行。
第六:變量
每個(gè)頁(yè)面都有生命周期的銷毀階段,在這階段里面講存在data里面的變量全部釋放(不會(huì)返回這頁(yè)面的時(shí)候可以這樣做),你二次進(jìn)入的時(shí)候會(huì)比上次快上一點(diǎn),但是不會(huì)很明顯,如果變量特別龐大的時(shí)候,這個(gè)時(shí)候就會(huì)顯得特別明顯,我做的都是二三十個(gè)變量。。。這個(gè)可以忽略
第七:緩存
相信每個(gè)頁(yè)面多多少少都會(huì)有復(fù)用的東西,如果有復(fù)用的變量,直接存到本地里面,然后等小程序整個(gè)關(guān)閉之后去本地儲(chǔ)存刪掉,
如果首頁(yè)加載的東西很多的,可以把整個(gè)頁(yè)面緩存下來(lái),然后,再次進(jìn)這頁(yè)面的時(shí)候渲染緩存的,等接口數(shù)據(jù)都請(qǐng)求到了,在進(jìn)行靜默渲染,
希望我講的額能幫到大家,感謝你的觀看
以上是“小程序加載快慢的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!