WebView能夠使得網頁輕鬆的內嵌到app裏,還能夠直接跟js相互調用。
webview有兩個方法:setWebChromeClient 和 setWebClient
setWebClient:主要處理解析,渲染網頁等瀏覽器作的事情
setWebChromeClient:輔助WebView處理Javascript的對話框,網站圖標,網站title,加載進度等
WebViewClient就是幫助WebView處理各類通知、請求事件的。
在AndroidManifest.xml設置訪問網絡權限:
<uses-permission android:name="android.permission.INTERNET"/>
控件:javascript
<WebView android:layout_width="match_parent" android:layout_height="match_parent" android:id="@+id/webView" />
example.html 存放在assets文件夾內.html
調用WebView的loadUrl()方法,java
加載本地資源 webView = (WebView) findViewById(R.id.webView); webView.loadUrl("file:///android_asset/example.html"); 加載web資源: webView = (WebView) findViewById(R.id.webView); webView.loadUrl("http://baidu.com");
建立一個本身的WebViewClient,經過setWebViewClient關聯android
import android.app.Activity; import android.os.Bundle; import android.webkit.WebView; import android.webkit.WebViewClient; publicclass MainActivity extends Activity { private WebView webView; @Override protectedvoid onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.test); init(); } privatevoid init(){ webView = (WebView) findViewById(R.id.webView); //WebView加載web資源 webView.loadUrl("http://baidu.com"); //覆蓋WebView默認使用第三方或系統默認瀏覽器打開網頁的行爲,使網頁用WebView打開 webView.setWebViewClient(new WebViewClient(){ @Override publicboolean shouldOverrideUrlLoading(WebView view, String url) { // TODO Auto-generated method stub //返回值是true的時候控制去WebView打開,爲false調用系統瀏覽器或第三方瀏覽器 view.loadUrl(url); returntrue; } }); } }
//啓用支持javascript WebSettings settings = webView.getSettings(); settings.setJavaScriptEnabled(true);
//改寫物理按鍵——返回的邏輯 @Override public boolean onKeyDown(int keyCode, KeyEvent event) { // TODO Auto-generated method stub if(keyCode==KeyEvent.KEYCODE_BACK) { if(webView.canGoBack()) { webView.goBack();//返回上一頁面 returntrue; } else { System.exit(0);//退出程序 } } return super.onKeyDown(keyCode, event); }
webView.setWebChromeClient(new WebChromeClient() { @Override public void onProgressChanged(WebView view, int newProgress) { // TODO Auto-generated method stub if (newProgress == 100) { // 網頁加載完成 } else { // 加載中 } } });
優先使用緩存 webView.getSettings().setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK); 不使用緩存: webView.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE);