Android原生控件 -- WebView
⒈用途
加载网页
-
- 加载URL(网络或者本地assets文件夹【这个文件夹下存放着我们不需要编译的资源文件,例如html等不需要编译成二进制代码】下的html文件)
- 加载html代码
- Native和JavaScript相互调用(混合调用)
⒉使用
加载网络URL
-
- webview.loadUrl("https://www.coreqi.cn");
**默认WebView不支持js(JavaScript),需要开启支持
-
- webview.getSettings().setJavaScriptEnabled(boolean flag);
加载assets文件夹下的html文件
-
- webview.loadUrl("file:///android_asset/test.html");
加载html代码
-
- webview.loadData(); //这个方法有时会出现例如乱码等情况
- webview.loadDataWithBaseURL(); //这个方法通常在编码设置方面相较好一些
网页的前进后退
-
- webview.canGoBack() //当前页面是否能够后退
- webview.goBack() //返回当前页面的上一个页面 (后退)
- webview.canGoForward() //当前页面是否能够前进
- webview.goForward() //返回当前页面的下一个页面(前进)
- webview.canGoBackOrForward(int steps) //是否能够返回或者前进
- webview.goBackOrForward(int steps) //前进或者后退几步
按下返回键,默认是退出当前Activity,如果希望是在WebView控件内后退,需要重写Activity的onKeyDown方法
@Override public boolean onKeyDown(int keyCode, KeyEvent event) { if(keyCode == KeyEvent.KEYCODE_BACK && webView.canGoBack()){ webView.goBack(); return true; //返回true表示当前事件已被处理,返回false则当前事件还将会继续传递 } return super.onKeyDown(keyCode, event); }
当然,也可以这样写
@Override public void onBackPressed() { if(webView.canGoBack()){ webView.goBack(); } super.onBackPressed(); }
WebView的跳转默认不是在WebView中继续加载的,而是调用手机浏览器去打开连接。我们可以继承WebViewClient去自定义
public class MyWebViewClient extends WebViewClient{ /** * 当页面跳转,就会调用该方法 * @param view * @param request * @return */ @Override public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) { //我们不希望调用本地浏览器去打开连接,我们希望能够在当前WebView中继续加载 view.loadUrl(request.getUrl().toString()); return true; } /** * 页面加载时执行 * @param view * @param url * @param favicon */ @Override public void onPageStarted(WebView view, String url, Bitmap favicon) { super.onPageStarted(view, url, favicon); } /** * 页面加载完成后执行 * @param view * @param url */ @Override public void onPageFinished(WebView view, String url) { super.onPageFinished(view, url); } }
webView.setWebViewClient(new MyWebViewClient());
***
public class MyWebChromeClient extends WebChromeClient{ /** * 获取网页加载进度,可以实现进度条功能 * @param view * @param newProgress */ @Override public void onProgressChanged(WebView view, int newProgress) { super.onProgressChanged(view, newProgress); } /** * 设置网页的Title * @param view * @param title */ @Override public void onReceivedTitle(WebView view, String title) { super.onReceivedTitle(view, title); setTitle(title); } }
WebView执行js(JavaScript)
webView.loadUrl("javascript:alert('hello')");
webView.evaluateJavascript("javascript:alert('hello')",null);
js(JavaScript)调用WebView方法
webView.addJavascriptInterface();