码迷,mamicode.com
首页 > 数据库 > 详细

用JavaScript探测页面上的广告是否被AdBlock屏蔽了的方法

时间:2014-12-05 19:13:25      阅读:218      评论:0      收藏:0      [点我收藏+]

标签:blog   io   使用   sp   java   on   div   问题   log   

每个人都讨厌广告。看电视、看电影、看优酷、看网页时,对满天飞的广告也是深恶痛绝。广告是一个不招人喜欢的东西。但是,对一个中小网站站长/博客主来说,广告几乎是唯一的能成支持网站/博客正常运转的资金来源。如果一个博客主,只是无私发布稿件,能坚持几年的,很少。大多数慢慢失去了热情。

火狐浏览器和谷歌浏览器里都有能够屏蔽页面给广告的插件,最有名的是AdBlock和AdBlock Plus。前几天,我做一个统计,看看浏览网站的用户中有多少人使用了AdBlock插件,发现这个数目竟然有总浏览人数的1/5。

1/5是一个不小的数目。如何能让广告位在这1/5的使用了AdBlock插件的用户的页面上用其它图片代替呢?要想做到这一点,首先是要有个办法知道当前浏览器中使用了AdBlock插件。经过一些测试,我发现,AdBlock对“Ad”或“Google AD”这样的词非常敏感,只要是某个页面元素的ID或css class名中有“Ad”字样的,这个元素基本上都会被AdBlock插件屏蔽掉,也就是display:none

 

<div class=‘google-ad testAd‘> 这个div将会被屏蔽掉 </div>

 

有了这个规律,我就能够使用JavaScript发现当前浏览器是否开启了AdBlock插件。首先,我们将Google广告代码放到一个div里,并且将div的css class name里放入一个很明显的表示google AD的类名:

<div class=‘google-ad testAd‘> 这里放置Google广告代码</div>

  然后在页面的底部用Js检测,:

if ($(‘.google-ad‘).height() == 0) showOtherImage();

  这里还有一个问题,Google的广告通常是指Dom加载完毕后显示的,为了保证在Google广告加载完成后再进行探测,要给js代码加入延迟执行特征,这样避免了误检测:

$(function(){
   setTimeout(function(){
		if ($(‘.google-ad‘).height() == 0)
			showOtherImage();
  },3000);
});

  这里的showOtherImage();方法里我们能做些什么呢?我们可以放一些京东、当当、亚马逊会其它网站的促销图片和链接,通过获取佣金,多少算是对损失的一点弥补。

用JavaScript探测页面上的广告是否被AdBlock屏蔽了的方法

标签:blog   io   使用   sp   java   on   div   问题   log   

原文地址:http://www.cnblogs.com/xupeiyu/p/4147131.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!