美文网首页
Android 关于WebView的使用技巧小解

Android 关于WebView的使用技巧小解

作者: 三横一竖的王1992 | 来源:发表于2017-12-01 19:33 被阅读0次

    前言

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

    1.加载url

    webView.loadUrl(url);
    

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

    2.加载进度条

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

    image.png

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

    2.1布局:

        <ProgressBar
            android:id="@+id/myProgressBar"
            style="?android:attr/progressBarStyleHorizontal"
            android:layout_width="match_parent"
            android:layout_height="2dp"/>
    

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


    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的使用技巧小解

          本文链接:https://www.haomeiwen.com/subject/wzbwbxtx.html