WebView相关面试题
1、如何提高WebView加載速度
美團(tuán)技術(shù)分享
WebView啟動(dòng)過(guò)程大概分為以下幾個(gè)階段:
App中打開WebView的第一步并不是建立連接,而是啟動(dòng)瀏覽器內(nèi)核。
優(yōu)化手段圍繞著以下兩個(gè)點(diǎn)進(jìn)行:
-
預(yù)加載WebView。
-
加載WebView的同時(shí),請(qǐng)求H5頁(yè)面數(shù)據(jù)。
常見的方法是全局WebView,在客戶端剛啟動(dòng)時(shí),就初始化一個(gè)全局的WebView待用,并隱藏;這種方法可以比較有效的減少WebView在App中的首次打開時(shí)間。當(dāng)用戶訪問頁(yè)面時(shí),不需要初始化WebView的時(shí)間。
當(dāng)然這也帶來(lái)了一些問題,包括:
- 額外的內(nèi)存消耗。
- 頁(yè)面間跳轉(zhuǎn)需要清空上一個(gè)頁(yè)面的痕跡,更容易內(nèi)存泄露。
- 客戶端代理頁(yè)面請(qǐng)求WebView初始化完成后向客戶端請(qǐng)求數(shù)據(jù)
- 在客戶端初始化WebView的同時(shí),直接由native開始網(wǎng)絡(luò)請(qǐng)求數(shù)據(jù);
- 當(dāng)頁(yè)面初始化完成后,向native獲取其代理請(qǐng)求的數(shù)據(jù)。
- asset存放離線包。
除此之外還有一些其他的優(yōu)化手段:
- DNS和鏈接慢:
- 想辦法復(fù)用客戶端使用的域名和鏈接,可以讓客戶端復(fù)用使用的域名與鏈接。
- DNS采用和客戶端API相同的域名
- DNS會(huì)在系統(tǒng)級(jí)別進(jìn)行緩存,對(duì)于WebView的地址,如果使用的域名與native的API相同,則可以直接使用緩存的DNS而不用再發(fā)起請(qǐng)求圖片。
- 腳本執(zhí)行慢:可以把框架代碼拆分出來(lái),在請(qǐng)求頁(yè)面之前就執(zhí)行好。
- 后端處理慢:可以讓服務(wù)器分trunk輸出,在后端計(jì)算的同時(shí)前端也加載網(wǎng)絡(luò)靜態(tài)資源。
2、WebView與 js的交互
Android去調(diào)用JS的代碼:
通過(guò)WebView的loadUrl()
通過(guò)WebView的evaluateJavascript()
JS調(diào)用Android代碼的方法:
通過(guò)WebView的addJavascriptInterface()進(jìn)行對(duì)象映射
通過(guò) WebViewClient 的shouldOverrideUrlLoading ()方法回調(diào)攔截 url
Android通過(guò) WebChromeClient 的onJsAlert()、onJsConfirm()、onJsPrompt(方法回調(diào)分別攔截JS對(duì)話框(即上述三個(gè)方法),得到他們的消息內(nèi)容,然后解析即可。
3、WebView的漏洞
Android WebView常見的安全漏洞和解決方案
4、JsBridge原理
JSBridge的原理
總結(jié)
以上是生活随笔為你收集整理的WebView相关面试题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 神秘的Flash Translation
- 下一篇: 微软新服务,允许企业扩大对其威胁情报库的