前言
WebView是安卓中的一个组件,它的作用,是可以用来加载Web网页,集成在android手机系统的app,则主要是加载h5的页面,下面就介绍一下,关于这个组件的一些常用小技巧。
1.加载url
webView.loadUrl(url);
注:webView.loadUrl(url),其中的url,可以加载三种不同的类型,可以是一个网页,也可以apk包中的html页面,还可以是手机本地的html页面。
2.加载进度条
由于webview加载的h5页面,非原生控件,若是内容较多时,加载的时间,可能会较长,为了缓解用户等待的焦躁,可以加入一个进度条的设置,从而让用户知晓,这个页面大约还有多久能加载出来,效果如下图所示:
而要实现这个效果代码如下:
2.1布局:
2.2代码:
@BindView(R.id.myProgressBar)
ProgressBar bar;
webView.setWebChromeClient(new WebChromeClient(){
@Override
public void onProgressChanged(WebView view, int newProgress) {
if (newProgress == 100) {
bar.setVisibility(View.INVISIBLE);
} else {
if (View.INVISIBLE == bar.getVisibility()) {
bar.setVisibility(View.VISIBLE);
}
bar.setProgress(newProgress);
}
super.onProgressChanged(view, newProgress);
});
注:1.布局中,progressPar的style属性,可以设置进度条的样式,若是不设置,默认为圆形;
2.setWebChromeClient下的 onProgressChanged就是监控原本用于webview来监控进度条的,所以,这个进度条是实时监控的真进度条,而不是假进度条。
3.与JS方法的交互
因为使用WebView所加载的是一个h5的网页,所以,想要对页面进行操作的话,最方便的办法,就是后台设置js的方法,前端去调用交互。
3.1在JS中调用本地java方法
代码如下:
//设置WebView支持JavaScript
webView.getSettings().setJavaScriptEnabled(true);
//在js中调用本地java方法
webView.addJavascriptInterface(new NativeModel(mContext), "NativeModel");
String id0;
String post_id0;
/**
* js调用方法
*/
private class NativeModel {
private Context mContext;
public NativeModel(Context context) {
this.mContext = context;
}
@JavascriptInterface
public void reply(String id, String post_id) {
id0 = id;
post_id0 = post_id;
}
}
注:1.NativeModel,这个应该是约定俗称的方法名;
2.js调用方法,一、是需要一个构造方法,而则是必要带上注解@JavascriptInterface;
3.代码中的reply方法,是我项目中的app,后台自定义的,而参数id与post_id,前者指代的页面id,后者指代条目id,从而对页面条目,进行回复处理;
最终效果如下图所示:
点击右下角的回复图标,可以获取到id与post_id,再配合上自家回复框的显示隐藏代码,就可以弹出对应的回复框,各位读者,可以根据自家app的需求,进行各自的交互实现。
3.2在java中截获JS的alert()方法,获取里面的内容
JS的aler()方法,其实就是一个弹窗方法,java有方法可以截获这个弹窗方法,获取其中的内容,从而进行一些操作。
实现代码如下:
//添加客户端支持
webView.setWebChromeClient(new WebChromeClient(){
@Override
public boolean onJsAlert(WebView view, String url, String message, JsResult result) {
Message obtain = Message.obtain();
obtain.obj = message;
obtain.what = HAND_SHARE;
handler.sendMessage(obtain);
result.confirm();
return true;
}
});
Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
switch (msg.what) {
case HAND_SHARE:
String result = (String) msg.obj;
ShareBean shareBean = new Gson().fromJson(result,ShareBean.class);
String title = shareBean.getTitle();
String content = shareBean.getContent();
title0 = title;
content0 = content;
break;
}
}
};
注:1.利用onJsAlert方法,截获其中的message,return true表示消耗掉alert弹窗事件,若是return false会弹出一个消息框;
2.其中的message,其实就是一个String字符串,而这里,比较特殊的是,这个字符串还是一个json串(这个json串是与后台定义的,不一定非要是json串),从而可以自定义一个bean类,对其进行解析,解析之后,可以获取对应的参数,在我开发的app中,获取的是这个页面的title(标题)以及content(内容),从而点击上图中的右上角,分享的图标,实现一些第三方的分享操作。
4.关于WebView一些余下的补充说明
先放一段代码:
if(Build.VERSION.SDK_INT>= Build.VERSION_CODES.LOLLIPOP){ //解决http头像加载不出的问题
webView.getSettings().setMixedContentMode(WebSettings.MIXED_CONTENT_ALWAYS_ALLOW);
}
webView.setWebViewClient(new WebViewClient() { //解决测试环境https证书不信任的问题
@Override
public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {
handler.proceed();
}
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
return super.shouldOverrideUrlLoading(view, url);
}
@Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
//当页面加载完成时,调用方法,获取需要分享的链接和信息
webView.loadUrl("javascript:alert(share())");
}
});
分部分拆解:
if(Build.VERSION.SDK_INT>= Build.VERSION_CODES.LOLLIPOP){
webView.getSettings().setMixedContentMode(WebSettings.MIXED_CONTENT_ALWAYS_ALLOW);
}
在5.0以上的系统,http的头像若是加载不出,可以使用这段代码解决;
@Override
public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {
handler.proceed();
}
这个方法,可以跳过https环境的检测,可以让https的头像加载出来,也可以解除一些证书不信任的问题;
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
return super.shouldOverrideUrlLoading(view, url);
}
这个方法,可以检测当前加载的h5页面,地址有没有发生改变;
@Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
//当页面加载完成时,调用方法,获取需要分享的链接和信息
webView.loadUrl("javascript:alert(share())");
}
这个方法,可以检测h5页面是否加载完毕,值得一提的是,上述3.2中获取分享信息的方法,需要在这个页面加载完全之后调用: webView.loadUrl("javascript:alert(share())");否则有可能会出现差错。
后记
学无止境,关于WebView这个组件,我也只使用过几次,了解的并不多,欢迎各位读者,补充说明,共同进步,在android技术开发这条道路上,长成自己想象的样子。