[安卓开发] WebView网页隐藏屏蔽广告元素标签|去除底部广告

简介

有时候,我们用WebView加载的某些网页里面常常有广告,大大的影响了使用者的浏览效果,我们能不能去除呢? 答案当然是可以的,当然方法是偏门一点,是利用js把对应的广告块进行隐藏。。

js代码

document.querySelector('广告块的选择器').style.display="none";

通过上面的js代码可以对某个元素进行隐藏,达到去除的目的,js 的代码解析就不多说了。

1. 怎么样获取唯一选择器:

首先一款好的浏览器(我这里用的是火狐浏览器), 例如这里我要隐藏跟踪快递单这个广告块,在需要隐藏的元素上右击,选择查看元素

这里写图片描述

可以看到蓝色那个div 是广告块的div

这里写图片描述

在这个div上面右击,选择 复制唯一选择器,这样这个广告块的 唯一选择器就复制了

这里写图片描述

然后回到安卓代码:

安卓代码

@Override
public void onPageFinished(WebView view, String url) {
      view.loadUrl("javascript:function setTop(){document.querySelector('.ad-footer').style.display=\"none\";}setTop();"); 
}

在WebView 的setWebViewClient方法下面重写onPageFinished,在页面加载完成时候,执行js代码进行隐藏,上面的 .ad-footer 就是刚刚复制的唯一选择器,至于为什么要写一个函数来执行,而不是直接执行,请看我上一篇文章。

ps: 由于很多手机的系统不一样,WebView的内核也有些许不同,导致一些没有及时回调onPageFinished的,所以最好再把隐藏的代码加到WebChromeClient的onProgressChanged 里面

 @Override
        public void onProgressChanged(WebView view, int newProgress) {

            view.loadUrl("javascript:function setTop(){document.querySelector('.ad-footer').style.display=\"none\";}setTop();"); 

            super.onProgressChanged(view, newProgress);
        }

这里写图片描述

注意,有问题

有时候是会出现一些问题的,例如要隐藏的网页是 异步加载的,异步加载的意思就是你前端网页加载onFinish了,但是里面的数据还没加载出来,数据是页面加载了之后才用ajax加载出来的,所以在onProgress和onFinish的时候,你要隐藏的元素还没有异步加载出来,就会导致隐藏不了。

这种情况是很多见的,解决方法我暂时只能想到三个:

1. 和网页进行交互

android和网页端进行交互,网页异步完成回调andoid端的方法,进行隐藏

2. 延迟执行

可以用handler.posetDelay或者view.postDelay 来延迟执行隐藏的js的方法。

3. 循环判断网页元素

利用jsoup循环进行WebView的网页源码解析,判断元素是否已经存在,存在就执行隐藏,结束循环。 当然也可以自己控制一下秒数最多循环多久。


完毕,谢谢浏览,有错误请指点。

AndroidWebView中,可以通过以下代码获取到指定class的元素内容: ```java WebView webView = findViewById(R.id.webview); webView.setWebViewClient(new WebViewClient() { @Override public void onPageFinished(WebView view, String url) { // 获取 class="example" 的元素内容 webView.loadUrl("javascript:window.android.onElementContentLoaded(document.getElementsByClassName('example')[0].innerHTML)"); } }); // 添加 JavaScript 接口 webView.addJavascriptInterface(new Object() { @JavascriptInterface public void onElementContentLoaded(String content) { // 处理获取到的元素内容 Log.d("WebView", "Element content: " + content); } }, "android"); ``` 在这个例子中,我们首先设置了WebViewClient的onPageFinished方法,当网页加载完成后会自动调用此方法。在这个方法中,我们通过JavaScript代码获取到指定class的元素内容,并通过WebView的loadUrl方法将获取到的内容回传给Android应用程序。 最后,我们通过addJavascriptInterface方法将一个Java对象添加为JavaScript接口,这个接口中包含了onElementContentLoaded方法,用于处理获取到的元素内容。在JavaScript代码中,我们通过window.android.onElementContentLoaded方法将获取到的元素内容传递给这个接口方法。 需要注意的是,这种方式可能会受到网页结构和JavaScript代码的影响,需要根据实际情况进行调整。同时,这种方式也可能会涉及到隐私和安全问题,请谨慎使用。
评论 29
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

KeepStudya

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值