Android 关于WebView的使用技巧小解

前言

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技术开发这条道路上,长成自己想象的样子。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,937评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,503评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,712评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,668评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,677评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,601评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,975评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,637评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,881评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,621评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,710评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,387评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,971评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,947评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,189评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,805评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,449评论 2 342

推荐阅读更多精彩内容