首页 > 代码库 > WebView使用

WebView使用

 WebView是View的一个子类,可以让你在activity中显示网页。

  可以在布局文件中写入WebView:比如下面这个写了一个填满整个屏幕的WebView: 

<?xml version="1.0" encoding="utf-8"?><WebView  xmlns:android="http://schemas.android.com/apk/res/android"    android:id="@+id/webview"    android:layout_width="fill_parent"    android:layout_height="fill_parent"/>

 

  加载一个网页,使用loadUrl()

WebView myWebView = (WebView) findViewById(R.id.webview);myWebView.loadUrl(http://www.example.com);
 

  注意要在manifest中加上访问网络的权限:

<manifest ... >     <uses-permission android:name="android.permission.INTERNET" />     ... </manifest>
 

设置WebView要显示的网页

  设置WevView要显示的网页方法有很多:

  互联网页面直接用: 

myWebView.loadUrl(“http://www.google.com“);

 

  本地文件用:

myWebView.loadUrl(“file:///android_asset/XX.html“);  

  本地文件存放在:assets文件中。

  还可以直接载入html的字符串,如:

String htmlString = "<h1>Title</h1><p>This is HTML text<br /><i>Formatted in italics</i><br />Anothor Line</p>";// 载入这个html页面myWebView.loadData(htmlString, "text/html", "utf-8");

 

 

在WebView中使用JavaScript

  如果你想要载入的页面中用了JavaScript,你必须为你的WebView使能JavaScript。

  一旦使能之后,你也可以自己创建接口在你的应用和JavaScript代码间进行交互。

使能JavaScript

  可以通过getSettings()获得WebSettings,然后用setJavaScriptEnabled()使能JavaScript:

WebView myWebView = (WebView) findViewById(R.id.webview);WebSettings webSettings = myWebView.getSettings();webSettings.setJavaScriptEnabled(true);

 

  WebSettings中提供了很多有用的设置。

处理页面浏览

  当用户点击了你的WebView中的一个链接,默认的行为是Android启动一个处理URL的应用,通常,默认的浏览器打开并下载目标URL。

  但是,你可以在你的WebView中覆盖这一行为,使得连接仍在你的WebView中打开。

  之后,根据在WebView中维护的网页浏览历史,你可以允许用户向前或向后浏览他们的网页。

在WebView中打开所有链接

  要打开用户点击的链接,只需要用setWebViewClient()方法向你的WebView提供一个WebViewClient 比如:

WebView myWebView = (WebView) findViewById(R.id.webview);myWebView.setWebViewClient(new WebViewClient());

  此时就OK了, 就可以在你的WebView中打开链接了。

关于打开链接位置的更多控制

  如果你对在哪里打开链接需要更多的控制,你可以创建自己的类,继承 WebViewClient,然后覆写shouldOverrideUrlLoading() 方法。

  比如下面这个:

    private class MyWebViewClient extends WebViewClient    {        @Override        public boolean shouldOverrideUrlLoading(WebView view, String url)        {
       if(Uri.parse(url).getHost().equals(www.example.com))
{ // This is my web site, so do not override; let my WebView load // the page return false; } // Otherwise, the link is not for a page on my site, so launch // another Activity that handles URLs Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(url)); startActivity(intent); return true; } }

 

  将特定的链接用自己的WebView打开,其他链接用浏览器(intent启动了默认的处理URL的Activity)。

  定义完之后把这个类的对象传入setWebViewClient()方法即可。 

WebView myWebView = (WebView) findViewById(R.id.webview);myWebView.setWebViewClient(new MyWebViewClient());

 

  实践验证:在直接设置setWebViewClient(new WebViewClient());时验证正确,即所有链接都是在WebView中打开。

  在设置为自定义的WebViewClient子类对象时,发现链接仍然都是从默认浏览器中打开。

 

浏览网页历史回退

  当你的WebView覆写了URL载入的行为,它会自动地对访问过的网页积累一个历史,你可以利用 goBack() 和 goForward()方法在这个历史中前进或后退。

  比如说使用后退键进行网页后退:

    /**     * 按键响应,在WebView中查看网页时,按返回键的时候按浏览历史退回,如果不做此项处理则整个WebView返回退出     */    @Override    public boolean onKeyDown(int keyCode, KeyEvent event)    {        // Check if the key event was the Back button and if there‘s history        if ((keyCode == KeyEvent.KEYCODE_BACK) && myWebView.canGoBack())        {            // 返回键退回            myWebView.goBack();            return true;        }        // If it wasn‘t the Back key or there‘s no web page history, bubble up        // to the default        // system behavior (probably exit the activity)        return super.onKeyDown(keyCode, event);    }

 

  canGoBack() 方法在网页可以后退时返回true。

  类似的,canGoForward()方法可以检查是否有可以前进的历史记录。

  如果你不执行这种检查,一旦 goBack() 和 goForward()方法到达历史记录顶端,它们将什么也不做。

  如果不加这种设置,在用户按下Back键时,如果是WebView显示网页,则会将WebView作为整体返回。

 

一份Demo示例:

	private void setWebView() {		mWebView.setWebViewClient(new WebViewClient() {			@Override			public void onPageFinished(WebView view, String url) {				// TODO Auto-generated method stub				mWebView.setVisibility(View.VISIBLE);				mWebView.getSettings().setBuiltInZoomControls(true);				mWebView.getSettings().setJavaScriptEnabled(true); 				mWebView.getSettings().setDefaultZoom(ZoomDensity.FAR);				mWebView.getSettings().setSupportZoom(true);				mWebView.setInitialScale(100);			}		});				mWebView.loadUrl("http://www.xxx.com");	}	 @Override	 public boolean onKeyDown(int keyCode, KeyEvent event) {	  if (keyCode == KeyEvent.KEYCODE_BACK && mWebView.canGoBack()) {	   mWebView.goBack();// 返回前一个页面	   return true;	  }	  return super.onKeyDown(keyCode, event);	 }