WebView (Android)使用
WebView 介绍
WebView是安卓平台用来显示网控件,可以实现App的混合开发需求。我们可能会有这样的需求,系统后台发送一个活动给用户,但是这个活动是会变化的,所以不能使用安卓的原生界面直接显示,那样会约束掉UI界面,使用网页来介绍活动就很有用了。
设置
当我们在布局文件里面添加了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(); }