本文實例為大家分享了Android Webview使用小結,供大家參考,具體內容如下
#采用重載URL的方式實現Java與Js交互
在Android中,常用的Java與Js交互的實現方式是通過函數addJavascriptInterface進行添加在Js中使用的回調代理類。
這種方法雖然方便,但是寫出來的js代碼并不通用。如果IOS也要實現類似的功能或業務,則IOS要另外寫一套Js代碼。所以不太推薦。
推薦使用重載URL的方式來實現,因為基本所有的平臺都擁有在加載某個URL之前進行一些處理的回調函數。所以這種方式會更加的通用。
#響應Javascript中的alert
在Android的WebView控件中,默認對JS的alert函數是沒有任何反應的
要想彈出對應的對話框,則需要我們自己進行實現
具體實現代碼如下:
webView.getSettings().setJavaScriptEnabled(true);webView.setWebChromeClient(new WebChromeClient(){ @Override public boolean onJsAlert(WebView view, String url, String message, final JsResult result) { AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this); builder.setTitle("測試alert"); builder.setMessage(message); builder.setPositiveButton("確定", new OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { result.confirm(); } }); builder.show(); return true; }});通過以上代碼就可以實現當JS中執行alert時,在Android上以原生的對話框顯示出來,當然這里也可以直接Toast。
而這段代碼中需要注意的地方有兩點:
1、返回值必須為true。
返回true,則說明已經處理了,不需要交由WebChromeClient來執行。而如果返回的是false,則Webview會繼續執行后續的js代碼,現象就是,彈出對話框之后,用戶還沒點確定,后續的js代碼已經執行完了.
2、最后必須調用result.confirm()。
原因在于,如果沒有調用此函數,則后續的JS代碼將無法繼續執行下去。最常見的現象就是,alert對話框只出現一次,第二次再進行alert的時候沒有任何反應。其實這里是因為沒有調用confirm函數,就相當于在瀏覽器中alert之后,用戶沒有點確定。
3、result.confirm()應該放到onClick回調中。
正如前面說的,調用confirm函數,就相當于用戶點擊了確定按鈕。因此,我們要把confirm函數的調用放到Android原生對話框的“確定”按鈕的回調函數中進行調用。
之前沒理解透,把confirm函數放在了builder.show之后進行調用,結果現象是alert之后,對話框彈出來了,但是后續的js代碼沒有阻塞,而是繼續執行下去了,變得就像是異步了一樣,和在chrome中調用js代碼的執行邏輯不一致。
不過,如果需求就是要直接執行下去,那也可以,只要理解了就行。
#訪問證書有問題的SSL網頁
對于有證書問題的網頁,比如過期、信息不正確、發行機關不被信任等,Webview默認情況下會拒絕訪問。而PC端瀏覽器的處理則是提供用戶進行選擇是否要繼續,在android也是可以實現的。
首先第一種是直接繼續,不需要讓用戶進行選擇
@Overridepublic void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) { // 默認為調用handler.cancel()方法,因此不要調用super的onReceivedSslError方法 // super.onReceivedSslError(view, handler, error); handler.proceed();}這里要注意的是,千萬不要調用super的onReceivedSslError方法,因為此方法中已經調用了handler.cancel()。
如果調用了,則會出現第一次無法加載,第二次卻能正常訪問的現象。
#慎重在shouldoverrideurlloading中返回true
當設置了WebviewClient時,在shouldoverrideurlloading中如果不需要對url進行攔截做處理,而是簡單的繼續加載此網址。
則建議采用返回false的方式而不是loadUrl的方式進行加載網址。
為什么這么建議呢?
因為如果采用loadUrl的方式進行加載,那么對于加載有跳轉的網址時,進行webview.goBack就會特別麻煩。
例如加載鏈接如下:
A->(B->C->D)->E 括號內為跳轉
如果采用return false的方式,那么在goBack的時候,可以從第二步直接回到A網頁。從E回到A只需要執行兩次goBack
而如果采用的是loadUrl,則沒辦法直接從第二步回到A網頁。因為loadUrl把第二步的每個跳轉都認為是一個新的網頁加載,因此從E回到A需要執行四次goBack
只有當不需要加載網址而是攔截做其他處理,如攔截tel:xxx等特殊url做撥號處理的時候,才應該返回true。
#onFormResubmission
原文鏈接:http://zlv.me/posts/2015/01/14/08_Android-Webview使用小結/
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。
|
新聞熱點
疑難解答