1. 打開網頁時不調用系統瀏覽器, 而是在本WebView中顯示:javascript
mWebView.setWebViewClient(new WebViewClient(){ @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url); return true; } });
2.經過java代碼調用javaScriptjava
WebSettings webSettings = mWebView .getSettings(); webSettings.setJavaScriptEnabled(true); mWebView.addJavascriptInterface(new Object() { public void clickOnAndroid() { mHandler.post(new Runnable() { public void run() { webview.loadUrl("javascript:wave()"); } }); } }, "demo");
3. 按返回鍵時, 不退出程序而是返回上一瀏覽頁面:web
public boolean onKeyDown(int keyCode, KeyEvent event) { if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView .canGoBack()) { webview.goBack(); return true; } return super.onKeyDown(keyCode, event); }
2.下面是設置一些經常使用屬性、狀態的方法
WebSettings經常使用方法:
setAllowFileAccess 啓用或禁止WebView訪問文件數據
setBlockNetworkImage 是否顯示網絡圖像
setBuiltInZoomControls 設置是否支持縮放
setCacheMode 設置緩衝的模式
setDefaultFontSize 設置默認的字體大小
setDefaultTextEncodingName 設置在解碼時使用的默認編碼
setFixedFontFamily 設置固定使用的字體
setJavaSciptEnabled 設置是否支持Javascript
setLayoutAlgorithm 設置佈局方式
setLightTouchEnabled 設置用鼠標激活被選項
setSupportZoom 設置是否支持變焦瀏覽器
WebViewClient經常使用方法:
doUpdate VisitedHistory 更新歷史記錄
onFormResubmission 應用程序從新請求網頁數據
onLoadResource 加載指定地址提供的資源
onPageFinished 網頁加載完畢
onPageStarted 網頁開始加載
onReceivedError 報告錯誤信息
onScaleChanged WebView發生改變
shouldOverrideUrlLoading 控制新的鏈接在當前WebView中打開緩存
WebChromeClient經常使用方法:
onCloseWindow 關閉WebView
onCreateWindow 建立WebView
onJsAlert 處理Javascript中的Alert對話框
onJsConfirm處理Javascript中的Confirm對話框
onJsPrompt處理Javascript中的Prompt對話框
onProgressChanged 加載進度條改變
onReceivedlcon 網頁圖標更改
onReceivedTitle 網頁Title更改
onRequestFocus WebView顯示焦點網絡
4. 打開頁面時, 自適應屏幕:ide
WebSettings webSettings = mWebView .getSettings(); webSettings.setUseWideViewPort(true);//設置此屬性,可任意比例縮放 webSettings.setLoadWithOverviewMode(true);
5. 便頁面支持縮放:函數
WebSettings webSettings = mWebView .getSettings(); webSettings.setJavaScriptEnabled(true); webSettings.setBuiltInZoomControls(true); webSettings.setSupportZoom(true);
6.若是webView中須要用戶手動輸入用戶名、密碼或其餘,則webview必須設置支持獲取手勢焦點。佈局
webview.requestFocusFromTouch();
7.WebView 加載界面主要調用三個方法:LoadUrl、LoadData、LoadDataWithBaseURL. post
1、LoadUrl 直接加載網頁、圖片並顯示.(本地或是網絡上的網頁、圖片、gif) 二、LoadData 顯示文字與圖片內容 (模擬器1.五、1.6) 三、LoadDataWithBase 顯示文字與圖片內容(支持多個模擬器版本)
8.WebSettings 的經常使用方法介紹
setJavaScriptEnabled(true); //支持js setPluginsEnabled(true); //支持插件 setUseWideViewPort(false); //將圖片調整到適合webview的大小 setSupportZoom(true); //支持縮放 setLayoutAlgorithm(LayoutAlgorithm.SINGLE_COLUMN); //支持內容從新佈局 supportMultipleWindows(); //多窗口 setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK); //關閉webview中緩存 setAllowFileAccess(true); //設置能夠訪問文件 setNeedInitialFocus(true); //當webview調用requestFocus時爲webview設置節點 webview webSettings.setBuiltInZoomControls(true); //設置支持縮放 setJavaScriptCanOpenWindowsAutomatically(true); //支持經過JS打開新窗口 setLoadWithOverviewMode(true); // 縮放至屏幕的大小 setLoadsImagesAutomatically(true); //支持自動加載圖片
9.WebViewClient 的方法全解
doUpdateVisitedHistory(WebView view, String url, boolean isReload) //(更新歷史記錄) onFormResubmission(WebView view, Message dontResend, Message resend) //(應用程序從新請求網頁數據) onLoadResource(WebView view, String url) // 在加載頁面資源時會調用,每個資源(好比圖片)的加載都會調用一次。 onPageStarted(WebView view, String url, Bitmap favicon) //這個事件就是開始載入頁面調用的,一般咱們能夠在這設定一個loading的頁面,告訴用戶程序在等待網絡響應。 onPageFinished(WebView view, String url) //在頁面加載結束時調用。一樣道理,咱們知道一個頁面載入完成,因而咱們能夠關閉loading 條,切換程序動做。 onReceivedError(WebView view, int errorCode, String description, String failingUrl)// (報告錯誤信息) onReceivedHttpAuthRequest(WebView view, HttpAuthHandler handler, String host,String realm)//(獲取返回信息受權請求) onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) //重寫此方法可讓webview處理https請求。 onScaleChanged(WebView view, float oldScale, float newScale) // (WebView發生改變時調用) onUnhandledKeyEvent(WebView view, KeyEvent event) //(Key事件未被加載時調用) shouldOverrideKeyEvent(WebView view, KeyEvent event)//重寫此方法纔可以處理在瀏覽器中的按鍵事件。 shouldOverrideUrlLoading(WebView view, String url) //在點擊請求的是連接是纔會調用,重寫此方法返回true代表點擊網頁裏面的連接仍是在當前的webview裏跳轉,不跳到瀏覽器那邊。這個函數咱們能夠作不少操做,好比咱們讀取到某些特殊的URL,因而就能夠不打開地址,取消這個操做,進行預先定義的其餘操做,這對一個程序是很是必要的。