好久没来博客了,最近工作中任务(Bug)比较多!除了改Bug之外发现最近新出的一部电视剧不错, 给大家推荐一下<<<<猎场>>>>
猎场.jpg
UIWebViewDelegate
- 好了,言归正传,今天遇到了一个关于UIWebView问题的问题,如何删除H5页面的广告问题(一般出现在第三方的H5页面的情况)
- APP中嵌入一个H5的网页,但出现的广告条或是无关头尾,相当大煞风景, 那该如何去掉呢?
- 嵌入webview 一段JavaScript代码来隐藏,目前Android和iOS都支持此方法(这就是iOS中常说的js和OC交互)
- UIWebVIew的基本使用这里就不多做介绍了
- 下面介绍一下UIWebViewDelegate的一些代理方法
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| optional public func webView(_ webView: UIWebView, shouldStartLoadWith request: URLRequest, navigationType: UIWebViewNavigationType) -> Bool
optional public func webViewDidStartLoad(_ webView: UIWebView)
optional public func webViewDidFinishLoad(_ webView: UIWebView)
optional public func webView(_ webView: UIWebView, didFailLoadWithError error: Error)
|
基于JavaScript的H5代码
首先,我们先看一下HTML5在浏览器中的现实情况, 参考地址
删除前的原网页
下面我们就要找到广告或者其他你想删除的部分对应的HTML代码
用浏览器打开参考地址, 建议使用谷歌浏览器
找到浏览器的开发者工具, 按照如下操作
查看网页代码
控制网页和js源码的显示方式
Snip20171111_6.png
- 调节手机/电脑显示: 你要选择在那种情境下显示网页,通俗来说,就是模拟器
- 放大镜:你可以通过放大镜对网页上的控件进行选取,然后找到html代码
- 手机:转化为手机模式,但是前提必须要转换Device的模式,要不然,光是视图上的转变,没有实际的转变(注意:我现在拿手机的网页做示例,所有我需要转化,当你做的电脑的就不需要转换这些了)
下面这就是要找到广告对应的js源码了(这里以订阅按钮为例)
Snip20171111_8.png
- 将右侧按钮为选中状态
- 用鼠标选中你要删除的控件(这里以订阅按钮为例), 这时你会发现右侧代码会有一行背景颜色被加深
- 我们要做的就是调用js语法删除这行js代码, 从而删除订阅按钮
- 找到该控件的class标签或者id标签
- 通过以下代码控制删除
1 2 3 4
| document.getElementsByClassName('gg-item news-gg-img3').style.display = 'none'
document.getElementsById('gg-item news-gg-img3').style.display = 'none'
|
- 如果找到的该控件所在的js代码没有class或者id标志, 可以继续找到其父控件,通过以下方式删除
1
| document.getElementsByClassName('gg-item news-gg-img3')[0].style.display='none'
|
具体核心代码如下
最终效果图
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
| extension NoneADViewController: UIWebViewDelegate{ func webViewDidFinishLoad(_ webView: UIWebView) { webView.stringByEvaluatingJavaScript(from: "document.getElementsByClassName('gg-item news-gg-img3')[0].style.display='none'") webView.stringByEvaluatingJavaScript(from: "document.getElementsByClassName('dbleleven-wrap')[0].style.display='none'") webView.stringByEvaluatingJavaScript(from: "document.getElementsByClassName('baiduimageplusm-title-img-only')[0].style.display = 'none'")
}
func webView(_ webView: UIWebView, shouldStartLoadWith request: URLRequest, navigationType: UIWebViewNavigationType) -> Bool { guard let urlStr = request.url?.absoluteString else { return true } print(urlStr)
return true } }
|