WebView (Android)使用

WebView 介绍

WebView是安卓平台用来显示网控件,可以实现App的混合开发需求。我们可能会有这样的需求,系统后台发送一个活动给用户,但是这个活动是会变化的,所以不能使用安卓的原生界面直接显示,那样会约束掉UI界面,使用网页来介绍活动就很有用了。
机核网的WebView显示文章

设置

当我们在布局文件里面添加了WebView控件之后,我们就可以对他进行操作了,首先需要对他进行设置,以满足你的需求。

获取WebSettings

WebSettings webSettings = webView.getSettings();

设置

//如果访问的页面中要与Javascript交互,则webview必须设置支持Javascript
webSettings.setJavaScriptEnabled(true);

// 若加载的 html 里有JS 在执行动画等操作,会造成资源浪费(CPU、电量)
// 在 onStop 和 onResume 里分别把 setJavaScriptEnabled() 给设置成 false 和 true 即可

//设置自适应屏幕,两者合用
webSettings.setUseWideViewPort(true); //将图片调整到适合webview的大小
webSettings.setLoadWithOverviewMode(true); // 缩放至屏幕的大小

//缩放操作
webSettings.setSupportZoom(true); //支持缩放,默认为true。是下面那个的前提。
webSettings.setBuiltInZoomControls(false); //设置内置的缩放控件。若为false,则该WebView不可缩放
webSettings.setDisplayZoomControls(false); //隐藏原生的缩放控件

//其他细节操作
webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK); //关闭webview中缓存
webSettings.setAllowFileAccess(true); //设置可以访问文件
webSettings.setJavaScriptCanOpenWindowsAutomatically(true); //支持通过JS打开新窗口
webSettings.setLoadsImagesAutomatically(true); //支持自动加载图片
webSettings.setDefaultTextEncodingName("utf-8");//设置编码格式

加载网页

//方式1. 加载一个网页:
webView.loadUrl("http://www.google.com/");

//方式2:加载apk包中的html页面
webView.loadUrl("file:///android_asset/test.html");

//方式3:加载手机本地的html页面
webView.loadUrl("content://com.android.htmlfileprovider/sdcard/test.html");

//方式4:加载html字符串
mWebView.loadData(htmlString,"text/html", "utf-8");

WebViewClient

用来处理各种通知和请求事件 常用的方法

  • shouldOverrideUrlLoading()
    当网页跳转到新的地址的时候执行,可以用来拦截跳转等,获取用来进行HTML和app的数据交互。

  • onPageStarted
    网页开始载入的时候调用。

  • onPageFinished
    网页加载结束的时候调用。

  • onReceivedError
    网页加载错误的时候调用,如404。

WebChromeClient

辅助 WebView 处理 Javascript 的对话框,网站图标,网站标题等等。

  • onProgressChanged
    网页加载进度变化的时候调用。

  • onReceivedTitle
    获取网页的标题。

  • onJsAlert
    当网页弹窗显示的时候调用。

  • onJsConfirm
    当网页点击了确认按钮时候调用。

注意事项:如何避免WebView内存泄露

  • 不在xml中定义 Webview ,而是在需要的时候在Activity中创建,并且Context使用 getApplicationgContext()
  • 在 Activity 销毁( WebView )的时候,先让 WebView 加载null内容,然后移除 WebView,再销毁 WebView,最后置空。
    @Override
    protected void onDestroy() {
        if (mWebView != null) {
            mWebView.loadDataWithBaseURL(null, "", "text/html", "utf-8", null);
            mWebView.clearHistory();
    
            ((ViewGroup) mWebView.getParent()).removeView(mWebView);
            mWebView.destroy();
            mWebView = null;
        }
        super.onDestroy();
    }
    
Search by:GoogleBingBaidu