class: center, middle # Co-existing with
**ad blockers** .small[[@CASCADE BOS meetup](http://www.meetup.com/cascadebos/events/230067856/) | Tue., June 28, 2016] Daigo Fujiwara, .small[Web Developer, WBUR, http://wbur.org] @DaigoFuji --- class: center, middle, inverse # Do you like
**Online Ads**? --- class: center, middle, white, big-img How about *MONEY*?
--- class: center, middle, white ## According to IAB (Interactive Advertising Bureau) U.S. Internet Ad Revenues was **$59.6 Billion** in 2015 .small[SOURCE: http://www.iab.com/insights/iab-internet-advertising-revenue-report-conducted-by-pricewaterhousecoopers-pwc-2/] --- class: center, middle, white data:image/s3,"s3://crabby-images/e3171/e317170760ca5c8daf1db06566852a0f7ce75d47" alt="img" --- class: center, middle, inverse # Ads are annoying... Didn't have to go far -- following screenshots are from yesterday.
Disclaimer: Not picking on anyone, we've all been there! --- class: center, middle, white, big-img NESN data:image/s3,"s3://crabby-images/56895/56895c55e103803bf572242035b907570d29621f" alt="img" --- class: center, middle, white, big-img CBS Boston data:image/s3,"s3://crabby-images/5cafc/5cafc449e9a67b9f55b935f081cab18cae563efc" alt="img" --- class: center, middle, white, big-img **TAKE OVER** on Boston.com data:image/s3,"s3://crabby-images/59e8a/59e8a26ffaf7a38cc424cc2b1ef37e0a47617e6e" alt="img" --- class: center, middle, inverse ## ...and under the hood, **the CODE...** --- class: middle, white ``` ``` .small[https://support.google.com/dfp_premium/answer/1638622?hl=en] --- class: center, middle, white # *document.write* .small[http://stackoverflow.com/questions/802854/why-is-document-write-considered-a-bad-practice] --- class: center, middle, inverse # Enter **Ad Blockers** --- class: center, middle, white # State of Ad Blocking 2016 Reuters Digital News report: **"24% of news consumers in U.S. block ads"** -- June 16, 2016 .small[http://digiday.com/publishers/global-state-of-ad-blocking/] --- class: center, middle, white, big-img [sourcepoint](http://sourcepoint.com/comscore-and-sourcepoint-the-state-of-ad-blocking/) June 2015: **1 in 10 U.S. surfers block ads** data:image/s3,"s3://crabby-images/c731f/c731f82da984db4762b381886982e3377cd6bbd8" alt="img" --- class: center, middle, inverse # Popular blockers Browser extensions --- class: center, middle, white ##Adblock Plus data:image/s3,"s3://crabby-images/3c84f/3c84fa8557bbe0017226d55e0592da2d903b9db1" alt="img" https://adblockplus.org/ --- class: center, middle, white ##TechCrunch: AdBlock Plus closes in on a billion downloads .small[https://techcrunch.com/2016/05/09/adblock-plus-closes-in-on-a-billion-downloads/] --- class: center, middle, white ##uBlock Origin data:image/s3,"s3://crabby-images/6a1c9/6a1c9c953edbc0b1f13026d946d9a336c1013691" alt="img" Open source, light weight. https://github.com/gorhill/uBlock --- class: center, middle, white ##Ghostery data:image/s3,"s3://crabby-images/b434d/b434d5ffcc766b3fd6bc87eca2044e1ea5f832e9" alt="img" "Tracking" blocker https://www.ghostery.com/ --- class: center, middle, white ## Sketchy part of ad blockers * White listing ([“Acceptable Ads” program](https://adblockplus.org/en/about#monetization))
* Collecting "tracker" data
* Extra processing-power usage --- class: center, middle, inverse ## **True or false:** if you don't have third-party javascript on your site, you don;t have to worry about ad blockers --- class: center, middle, white #
CSS Demo
[source code on github](https://github.com/daigofuji/co-exist-w-ad-blocker/blob/gh-pages/demo-css.html) --- class: middle, white ``` :root .adsbox, :root .ad-link, :root .ad-text, :root .ad-content, :root .ad-label, :root .ad-inner, :root .ad.super { display:none !important; } ``` Example CSS Override from uBlok Origin. --- class: center, middle, white #
Javascript Demo
[source code on github](https://github.com/daigofuji/co-exist-w-ad-blocker/blob/gh-pages/demo-js.html) --- class: center, middle, inverse # Where do they get that list? --- class: center, middle, white #**EasyList** https://easylist.github.io/ [easylist_general_hide.txt](https://github.com/easylist/easylist/blob/master/easylist/easylist_general_hide.txt)
[easylist_general_block.txt](https://github.com/easylist/easylist/blob/master/easylist/easylist_general_block.txt) --- class: center, middle, inverse # Counter Tools --- class: center, middle, white #**BlockAdBlock** https://github.com/sitexw/BlockAdBlock A.K.A. F*ckAdBlock, ready-to-use library --- class: center, middle, white #**DetectAdBlock.com** http://www.detectadblock.com/ Tutorial on how to test by loading "ads.js" (used in my
JavaScript Demo
) --- class: center, middle, white # **Heilmann method** https://www.christianheilmann.com/2015/12/25/detecting-adblock-without-an-extra-http-overhead/ Check the ad styled div to see if it is `display: none`, by testing `test.offsetHeight === 0`
Demo
[source code on github](https://github.com/daigofuji/co-exist-w-ad-blocker/blob/gh-pages/demo-test.html) --- class: center, middle, white ## And then there are counter-counter tools https://github.com/reek/anti-adblock-killer Which lists [all the ad block blocker](https://github.com/reek/anti-adblock-killer/blob/master/anti-adblock-killer-filters.txt) --- class: middle, white ##In conclusion * Internet ads suck. * Ads and ad blockers are here to stay. * Ad blockers are also business. * Learn to live with them. --- class: center, middle, white, big-img data:image/s3,"s3://crabby-images/8fe5b/8fe5bf421d616fe038114b4b90da16889621ad88" alt="img" --- class: middle, center, white, big-img
**Thank you!**
https://github.com/daigofuji/co-exist-w-ad-blocker @DaigoFuji on
&