网上关于webView的介绍很多很全,例如简书https://www.jianshu.com/p/32d48ca7d0e0
下面是一个webview的简单demo
1、activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<WebView
android:id="@+id/webview"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
<ProgressBar
android:id="@+id/progressbar"
style="@android:style/Widget.ProgressBar.Horizontal"
android:layout_width="match_parent"
android:layout_height="3dip"
android:max="100"
android:progress="0"
android:visibility="gone"/>
</FrameLayout>
2、MainActivity.class
public class MainActivity extends AppCompatActivity {
private WebView webView;
private ProgressBar progressBar;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
progressBar= (ProgressBar)findViewById(R.id.progressbar);//进度条
webView = (WebView) findViewById(R.id.webview);
webView.loadUrl("file:///android_assets/test.html");
webView.addJavascriptInterface(this,"android");//添加js监听 这样html就能调用客户端
webView.setWebChromeClient(webChromeClient);
webView.setWebViewClient(webViewClient);
WebSettings webSettings=webView.getSettings();
webSettings.setJavaScriptEnabled(true);//允许使用js
/**
* LOAD_CACHE_ONLY: 不使用网络,只读取本地缓存数据
* LOAD_DEFAULT: (默认)根据cache-control决定是否从网络上取数据。
* LOAD_NO_CACHE: 不使用缓存,只从网络获取数据.
* LOAD_CACHE_ELSE_NETWORK,只要本地有,无论是否过期,或者no-cache,都使用缓存中的数据。
*/
webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);//不使用缓存,只从网络获取数据.
webSettings.setSupportZoom(true);
webSettings.setBuiltInZoomControls(true);
}
//WebViewClient主要帮助WebView处理各种通知、请求事件
private WebViewClient webViewClient=new WebViewClient(){
@Override
public void onPageFinished(WebView view, String url) {//页面加载完成
progressBar.setVisibility(View.GONE);
}
@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {//页面开始加载
progressBar.setVisibility(View.VISIBLE);
}
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
//拦截请求
return super.shouldOverrideUrlLoading(view, url);
}
};
//WebChromeClient主要辅助WebView处理Javascript的对话框、网站图标、网站title、加载进度等
private WebChromeClient webChromeClient=new WebChromeClient(){
//不支持js的alert弹窗,需要自己监听然后通过dialog弹窗
@Override
public boolean onJsAlert(WebView webView, String url, String message, JsResult result) {
AlertDialog.Builder localBuilder = new AlertDialog.Builder(webView.getContext());
localBuilder.setMessage(message).setPositiveButton("确定",null);
localBuilder.setCancelable(false);
localBuilder.create().show();
result.confirm();
return true;
}
//获取网页标题
@Override
public void onReceivedTitle(WebView view, String title) {
super.onReceivedTitle(view, title);
}
//加载进度回调
@Override
public void onProgressChanged(WebView view, int newProgress) {
progressBar.setProgress(newProgress);
}
};
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
//防止点击返回键后直接退出程序
if (webView.canGoBack() && keyCode == KeyEvent.KEYCODE_BACK){//点击返回按钮的时候判断有没有上一页
webView.goBack(); // goBack()表示返回webView的上一页面
return true;
}
return super.onKeyDown(keyCode,event);
}
/**
* JS调用android的方法
* @param str
* @return
*/
@JavascriptInterface /
public void getClient(String str){
}
@Override
protected void onDestroy() {
super.onDestroy();
//activity关闭时需要手动释放webview内存
if (webView != null) {
webView.stopLoading();
webView.setWebViewListener(null);
webView.clearHistory();
webView.clearCache(true);
webView.loadUrl("about:blank");
webView.pauseTimers();
webView = null;
}
}
}
这里加载的是app资源文件夹下面的html文件,需要自main文件夹下面新建资源文件夹assets,然后在该文件夹下面新建test.html
test.html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<title>这是标题啊</title>
<style type="text/css">
dd {
margin-top:30px; /* 上外边距30像素 */
}
</style>
</head>
<body>
<div id="wrap">
<div id="header"><h1>Webview简单使用</h1>
</div>
<div id="main">
<dl>
<dd><a href="http://www.baidu.com">点击跳转到百度</a></dd>
<dd>
<button id='callback_client' onclick="callBackClient()" type="button">用js调用客户端
</button>
</dd>
</dl>
</div>
</body>
<script>
function callBackClient(){
alert("弹窗");
javascript:android.getClient("传一个字符串给客户端");//调用客户端
}
</script>
</html>