Android 关于WebView的使用技巧小解

前言

WebView是安卓中的一个组件,它的作用,是可以用来加载Web网页,集成在android手机系统的app,则主要是加载h5的页面,下面就介绍一下,关于这个组件的一些常用小技巧。

1.加载url

webView.loadUrl(url);

注:webView.loadUrl(url),其中的url,可以加载三种不同的类型,可以是一个网页,也可以apk包中的html页面,还可以是手机本地的html页面。

2.加载进度条

由于webview加载的h5页面,非原生控件,若是内容较多时,加载的时间,可能会较长,为了缓解用户等待的焦躁,可以加入一个进度条的设置,从而让用户知晓,这个页面大约还有多久能加载出来,效果如下图所示:

Android 关于WebView的使用技巧小解_第1张图片
image.png

而要实现这个效果代码如下:

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,从而对页面条目,进行回复处理;
最终效果如下图所示:


Android 关于WebView的使用技巧小解_第2张图片
image.png

点击右下角的回复图标,可以获取到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技术开发这条道路上,长成自己想象的样子。

你可能感兴趣的:(Android 关于WebView的使用技巧小解)