欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS?WKWebView秒開(kāi)方案實(shí)戰(zhàn)記錄

 更新時(shí)間:2021年12月10日 10:59:23   作者:鐘環(huán)  
從iOS8開(kāi)始,就引入了新的瀏覽器控件WKWebView,用于取代UIWebView,下面這篇文章主要給大家介紹了關(guān)于iOS?WKWebView秒開(kāi)方案的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

WKWebView 秒開(kāi)方案,不僅需要端上優(yōu)化,也需要前后端配合,我們業(yè)務(wù)前期在UIWebView上已經(jīng)通過(guò)各種優(yōu)化達(dá)到了秒開(kāi),但是由于蘋(píng)果2020年12月份就不允許上架UIWebView,所以我們緊急切換到WKWebView,但由于WKWebView在啟動(dòng)初始化的時(shí)候表現(xiàn)還是不如人意,我們的目標(biāo)是低端機(jī)型至少大部分頁(yè)面也能秒開(kāi)。經(jīng)過(guò)一系列的優(yōu)化操作,實(shí)現(xiàn)效果和數(shù)據(jù)都是非??捎^的。

秒開(kāi)流程圖

秒開(kāi)方案

1、模板下載。

2、首圖預(yù)加載。

3、正文列表body預(yù)取。

4、CDN預(yù)加載。

5、雙緩存池(目前一共不超過(guò)8個(gè)):一個(gè)負(fù)責(zé)feed流列表滾動(dòng)停止時(shí)異步執(zhí)行js預(yù)熱;一個(gè)負(fù)責(zé)進(jìn)入文章后準(zhǔn)備好一個(gè)干凈的WKWebview供下一次未命中秒開(kāi)WKWebview使用。

6、點(diǎn)擊cell命中預(yù)熱好的秒開(kāi)WKWebview,則進(jìn)行預(yù)熱下一篇文章,這樣提高秒開(kāi)率。

7、initpage預(yù)熱好的WebView需要先放在屏幕最右側(cè)隱藏,在進(jìn)入后顯示并重設(shè)frame回歸正常視圖中。

8、feed流預(yù)熱的WebView通過(guò)initPage傳false參數(shù)、進(jìn)入文章頁(yè)后的WebView通過(guò)initPage傳true參數(shù),為保證不會(huì)刷新跳動(dòng),模板中有設(shè)置flag確保一次initPage

9、動(dòng)態(tài)js回填方案:load模板 → 成功會(huì)收到前端橋接Ready狀態(tài) → 客戶端收到Ready狀態(tài)會(huì)進(jìn)行initPage操作,此時(shí)只是靜態(tài)加載頁(yè)面渲染顯示給用戶看的界面,不會(huì)觸發(fā)任何網(wǎng)絡(luò)或其他模板加載,initPage成功后會(huì)回調(diào)init狀態(tài) → 客戶端收到init狀態(tài)會(huì)進(jìn)行執(zhí)行showPage操作,表示已經(jīng)進(jìn)入頁(yè)面需要繼續(xù)加載好所有未加載好的邏輯,例如圖片渲染、網(wǎng)絡(luò)請(qǐng)求、模板加載等,showPage成功后前端回調(diào)show狀態(tài) → 客戶端仍為頁(yè)面已經(jīng)加載完成,處理加載完成后的邏輯,例如打點(diǎn)上報(bào)等

10、全局并沒(méi)有持有WKWebview不釋放,而是只要進(jìn)入文章頁(yè)就會(huì)預(yù)創(chuàng)建下次需要預(yù)熱的WKWebview,保證每次的WKWebview都是干凈無(wú)歷史痕跡,在dealloc方法中會(huì)釋放雙緩存池當(dāng)前加載的WebView。

其中initpage和showPage等都是前端處理相關(guān)邏輯回調(diào)給客戶端狀態(tài),客戶端拿到狀態(tài)進(jìn)行下一步操作。

技術(shù)數(shù)據(jù)

Item 端到端平均耗時(shí) 端到端p90耗時(shí)
對(duì)照組 1210 ms 2800 ms
實(shí)驗(yàn)組 780 ms 1800 ms

秒開(kāi)效果對(duì)比

低端機(jī)型:真機(jī)6P,12.4.5系統(tǒng)

優(yōu)化前線上UIWebview展示:

WKWebview展示:

WKWebView究竟好在哪里呢?

  1. 內(nèi)存開(kāi)銷(xiāo)更小
  2. 內(nèi)置手勢(shì)
  3. 支持更多H5特性
  4. 有Safari相同的JavaScript引擎
  5. 提供更多屬性,比如加載進(jìn)度、標(biāo)題、準(zhǔn)確的得到頁(yè)面數(shù)等等
  6. 提供了更精細(xì)的加載流程回調(diào)(當(dāng)然相比UIWebView看起來(lái)也更麻煩一些,畢竟方法多了)

總結(jié)

到此這篇關(guān)于iOS WKWebView秒開(kāi)方案的文章就介紹到這了,更多相關(guān)iOS WKWebView秒開(kāi)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 淺談iOS開(kāi)發(fā)中static變量的三大作用

    淺談iOS開(kāi)發(fā)中static變量的三大作用

    下面小編就為大家?guī)?lái)一篇淺談iOS開(kāi)發(fā)中static變量的三大作用。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-03-03
  • IOS 開(kāi)發(fā)之UITableView 刪除表格單元寫(xiě)法

    IOS 開(kāi)發(fā)之UITableView 刪除表格單元寫(xiě)法

    這篇文章主要介紹了IOS 開(kāi)發(fā)之UITableView 刪除表格單元寫(xiě)法的相關(guān)資料,這里提供實(shí)例幫助大家實(shí)現(xiàn)該功能,希望能幫助到大家,需要的朋友可以參考下
    2017-08-08
  • 淺談Xcode9 和iOS11適配和特性

    淺談Xcode9 和iOS11適配和特性

    本篇文章主要介紹了Xcode9 和iOS11適配和特性,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09
  • 混合棧跳轉(zhuǎn)導(dǎo)致Flutter頁(yè)面事件卡死問(wèn)題解決

    混合棧跳轉(zhuǎn)導(dǎo)致Flutter頁(yè)面事件卡死問(wèn)題解決

    這篇文章主要為大家介紹了混合棧跳轉(zhuǎn)導(dǎo)致Flutter頁(yè)面事件卡死問(wèn)題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • iOS實(shí)現(xiàn)富文本編輯器的方法詳解

    iOS實(shí)現(xiàn)富文本編輯器的方法詳解

    大家在開(kāi)發(fā)的時(shí)候經(jīng)常會(huì)用到富文本編輯器,所以這篇文章就給大家整理了如何使用iOS實(shí)現(xiàn)富文本編輯器的方法,相信本文對(duì)大家具有一定的參考借鑒價(jià)值,有需要的朋友們可以一起來(lái)看看。
    2016-10-10
  • iOS實(shí)現(xiàn)聯(lián)系人列表功能

    iOS實(shí)現(xiàn)聯(lián)系人列表功能

    這篇文章主要為大家詳細(xì)介紹了iOS實(shí)現(xiàn)聯(lián)系人列表功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • iOS開(kāi)發(fā)驗(yàn)證判斷語(yǔ)句之正則表達(dá)式小結(jié)

    iOS開(kāi)發(fā)驗(yàn)證判斷語(yǔ)句之正則表達(dá)式小結(jié)

    最近在公司接手重構(gòu)一個(gè)項(xiàng)目,發(fā)現(xiàn)之前的開(kāi)發(fā)在驗(yàn)證格式這塊寫(xiě)的太亂了,到處都有相關(guān)的驗(yàn)證代碼,所以就有了這篇文章,供自己收藏也分享給有需要的朋友們參考借鑒,下面跟著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2016-12-12
  • IOS代碼筆記UIView的placeholder的效果

    IOS代碼筆記UIView的placeholder的效果

    這篇文章主要為大家詳細(xì)介紹了IOS實(shí)現(xiàn)placeholder效果的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-07-07
  • iOS開(kāi)發(fā)實(shí)現(xiàn)抽屜效果

    iOS開(kāi)發(fā)實(shí)現(xiàn)抽屜效果

    這篇文章主要為大家詳細(xì)介紹了iOS開(kāi)發(fā)實(shí)現(xiàn)抽屜效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • iOS中UITableView Cell實(shí)現(xiàn)自定義單選功能

    iOS中UITableView Cell實(shí)現(xiàn)自定義單選功能

    本篇文章主要介紹了iOS中UITableView Cell實(shí)現(xiàn)自定義單選功能,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-02-02

最新評(píng)論