上篇博文中,我们已经知道了如何通过js去控制webview中一些页面的变化和操作,今天,我们来玩一个更好玩的,或许有玩过掘金客户端的都知道,我们在点击页面的时候,掘金客户端并不是直接在webview页面进行加载,而是通过打开另一个Activity进行呈现,忽然发现这种方式真的挺不错的,玩过webview的都知道,我们在做一个页面的前进和后退时,我们会因为goBack返回页面的时候,页面会进行重新加载,造成体验不太舒服,虽然有解决方法,但是,页面一直都处于当前Activity状态,给用户的感觉就是这个和浏览器有啥区别,感觉太枯燥。所以为了解决这些问题,我看了淘宝客户端在处理这些页面的时候也是跳转一个新的Activity去加载这个url,感觉体验还是很不错的,所以,今天小试了一下,分享出来。


效果图:

iOS WKUserScript js注入 webview js注入_webview

该部分主要讲js的注入,代码如何组织可以看上篇文章,该篇只需在上一篇的onPageFinished的回调中添加js代码即可。

还是老规矩,对于js的操作,我们还是先在html代码中测试一下,然后再应用到android中。

我们先给出个错误的示范,然后再给正确的示范,如果我们按照上一篇获取图片那么玩的话,那代码就如下。

var href = document.getElementsByTagName("a");
        for(var i = 0; i < href.length; i++) {
            var a = document.getElementsByTagName("a")[i];
            a.onclick = function() {
                alert(a.href);
            };
        }

看看效果图:

iOS WKUserScript js注入 webview js注入_跳转Activity_02

大家看懂错误的地方在哪了吗?如果我们应用了这段js代码,那么我们在webview中使用的话,即使我们打开了一个新的Activity,但是,原来的webview还是会继续加载,等我们返回查看上一个页面的时候,我们发现,怎么和我们退出来的界面一样的呢,我们的目的应该是能获取到alert提示出来的url链接,但是,不能让当前页面去刷新,然后将这个url交给另一个开启的Activity去webView加载处理。

我们知道,我们在网页开发中,a标签在有href属性的时候就具有网页跳转的意思,即使href属性值为空,他也会发生刷新,只不过不跳转,而是在当前页面进行刷新,这种效果在webview中也是不能存在,我们不允许在跳转Activity的,之前的页面发生刷新,可是,网页中的代码都有href属性。

所以我们首先要做的就是禁止掉这个href的触发,我查看了一下js的使用,找到了禁止href使用的代码

iOS WKUserScript js注入 webview js注入_注入js_03

所以,我接下来把代码这么改了一下

var href = document.getElementsByTagName("a");
        for(var i = 0; i < href.length; i++) {
            var a = document.getElementsByTagName("a")[i];
            a.href="javascript:void(0)";
            a.onclick = function() {
                alert(a.href);
            };
        }

然后试着运行了一下,我的天,怎么alert出来的全是javascript:void(0),之前的url全没了,后来一想,确实也对,为了禁止href的触发,我把href全替换成了javascript:void(0),所以,这样的错误肯定是不可避免的,这段代码也不对。

禁止href肯定是对的, 关键在于如何去处理这个url链接,后来我一想,既然链接不能放在href,我换个属性放不就行了嘛,然后alert的时候,直接去找存放的那个属性拿不就行了吗,那就马上动手操作,我把代码改成如下方式。

var href = document.getElementsByTagName("a");
        for(var i = 0; i < href.length; i++) {
            var a = document.getElementsByTagName("a")[i];
            a.onclick = function() {
                alert(a.value);
            };
            a.value = a.href;
            a.href = "javascript:void(0)";
        }

结果如图:

iOS WKUserScript js注入 webview js注入_javascript_04

哈哈,没有发生刷新,而且还拿到了链接,这就是我们需要的结果,那就赶紧应用到代码上面吧,下面就贴出主要部分的代码。

@Override
            public void onPageFinished(WebView view, String url) {
                super.onPageFinished(view, url);
                 view.loadUrl("javascript: function next(){" +
                        "var href=document.getElementsByTagName(\"a\");\n" +
                        "\t\t for(var i=0;i<href.length;i++){\n" +
                        "\t\t \t   var a=document.getElementsByTagName(\"a\")[i];\n" +
                        "\t\t \t   a.onclick=function(){\n" +
                        "\t\t \t   \t\t window.jsAndroid.onNextPage(this.value);\n" +
                        "\t\t \t   };\n" +
                        "\t\t \t   a.value=a.href;" +
                        "\t\t \t   a.href=\"javascript:void(0)\";\n" +
                        "\t\t }" +
                        "}");

                view.loadUrl("javascript:next()");
             }
class JSObject {
        @JavascriptInterface
        public void onNextPage(String href) {
            Log.i(TAG, "href---------->" + href);
            Intent intent = new Intent(MainActivity.this, MainActivity.class);
            intent.putExtra("url", href);
            startActivity(intent);
        }
   }

ok搞定,看我截图的肯定还会有一个发现,我把获取图片的js也放在上面去了,赶紧mark吧。