⒈用途
加载网页
⒉使用
加载网络URL
**默认WebView不支持js(JavaScript),需要开启支持
加载assets文件夹下的html文件
加载html代码
网页的前进后退
按下返回键,默认是退出当前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();
原文:https://www.cnblogs.com/fanqisoft/p/12159725.html