Android 4.4 中 WebView 使用注意事項
自Android 4.4起,Android中的WebView開始基于Chromium( 這大概是因為Android部門負責人從Andy Rubin變成了Chrome部門的主管Sundar Pichai了吧,^_^)。
這個改變使得WebView的性能大幅度提升,并且對HTML5, CSS3, and JavaScript有了更好的支持。
那么,作為一個客戶端開發者,我們寫代碼的時候需要注意哪些呢?
1.多線程
如果你在子線程中調用WebView的相關方法,而不在UI線程,則可能會出現無法預料的錯誤。
所以,當你的程序中需要用到多線程時候,也請使用 runOnUiThread()方法來保證你關于WebView的操作是在UI線程中進行的:
runOnUiThread(newRunnable(){
@Override
publicvoid run(){
// Code for WebView goes here
}
}); 2.線程阻塞
永遠不要阻塞UI線程,這是開發Android程序的一個真理。雖然是真理,我們卻往往不自覺的犯一些錯誤違背它,一個開發中常犯的錯誤就是:在UI線程中去等待JavaScript 的回調。
例如:
// This code is BAD and will block the UI thread
webView.loadUrl("javascript:fn()"); while(result ==null){
Thread.sleep(100); } 千萬不要這樣做,Android 4.4中,提供了新的Api來做這件事情。evaluateJavascript() 就是專門來異步執行JavaScript代碼的。
3.evaluateJavascript() 方法
專門用于異步調用JavaScript方法,并且能夠得到一個回調結果。
示例:
mWebView.evaluateJavascript(script, new ValueCallback<String>() {
@Override
public void onReceiveValue(String value) {
//TODO
}
}); 4.處理 WebView 中 url 跳轉
新版WebView對于自定義scheme的url跳轉,新增了更為嚴格的限制條件。當你實現了 shouldOverrideUrlLoading() 或 shouldInterceptRequest() 回調,WebView 也只會在跳轉url是合法Url時才會跳轉。
例如,如果你使用這樣一個url :
<ahref="showProfile"]]>Show Profile</a>
正確的使用方式是:
<ahref="example-app:showProfile"]]>Show Profile</a>
對應的檢測Url跳轉的方式:
// The URL scheme should be non-hierarchical (no trailing slashes)
privatestaticfinalString APP_SCHEME ="example-app:";
@Override publicboolean shouldOverrideUrlLoading(WebView view,String
url){
if(url.startsWith(APP_SCHEME)){
urlData =URLDecoder.decode(url.substring(APP_SCHEME.length()),"UTF-8");
respondToData(urlData);
returntrue;
}
returnfalse; } 當然,也可以這樣使用:
webView.loadDataWithBaseURL("example-app://example.co.uk/", HTML_DATA,
null,"UTF-8",null); 5.UserAgent 變化
如果你的App對應的服務端程序,會根據客戶端傳來的UserAgent來做不同的事情,那么你需要注意的是,新版本的WebView中,UserAgent有了些微妙的改變:
Mozilla/5.0 (Linux; Android 4.4; Nexus 4 Build/KRT16H) AppleWebKit/537.36(KHTML, like Gecko) Version/4.0 Chrome/30.0.0.0 Mobile Safari/537.36
使用 getDefaultUserAgent()方法可以獲取默認的UserAgent,也可以通過:
mWebView.getSettings().setUserAgentString(ua); mWebView.getSettings().getUserAgentString();
來設置和獲取自定義的UserAgent。
6.使用addJavascriptInterface()的注意事項
從Android4.2開始。只有添加 @JavascriptInterface 聲明的Java方法才可以被JavaScript調用,例如:
class JsObject {
@JavascriptInterface
public String toString() { return "injectedObject"; }
}
webView.addJavascriptInterface(new JsObject(), "injectedObject");
webView.loadData("", "text/html", null);
webView.loadUrl("javascript:alert(injectedObject.toString())"); 7.Remote Debugging
新版的WebView還提供了一個很厲害的功能:使用Chrome來調試你運行在WebView中的程序。
具體可以看:remote-debugging
原文:github文檔