精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

重寫document.write實現(xiàn)無阻塞加載JS廣告

開發(fā) 前端
無阻塞加載javascript,對于頁面性能優(yōu)化有很大的作用,這樣能有效的減少js對頁面加載的阻塞。特別是一些廣告js文件,由于廣告內(nèi)容有可能是富媒體,更是很可能成為你頁面加載提速的瓶頸,高性能javascript告訴我們,同學,提升你的網(wǎng)頁速度,就無阻塞地加載JS吧。

無阻塞加載javascript,對于頁面性能優(yōu)化有很大的作用,這樣能有效的減少js對頁面加載的阻塞。特別是一些廣告js文件,由于廣告內(nèi)容有可能是富媒體,更是很可能成為你頁面加載提速的瓶頸,高性能javascript告訴我們,同學,提升你的網(wǎng)頁速度,就無阻塞地加載JS吧。

于是便有一下代碼出現(xiàn)。

  1. (function() {  
  2. var s = document.createElement('script');  
  3. s.type = 'text/javascript';  
  4. s.async = true;  
  5. s.src = 'http://yourdomain.com/script.js';  
  6. var x = document.getElementsByTagName('script')[0];  
  7. x.parentNode.insertBefore(s, x);  
  8. })(); 

上邊都是大家熟悉的,看過書的同學都知道這樣無阻塞加載的好處,效果挺不錯的,當此等無阻塞腳本遇到一般js廣告就來了寫問題——廣告代碼出現(xiàn)在HTML里面了卻不顯示廣告。

納尼?HTML出來了不渲染到頁面上?

先看看廣告js代碼

  1. document.write('<img src="http://images.cnblogs.com/logo_small.gif" alt="Logo">'); 

代碼挺簡單就一個document.write輸出HTML代碼(相信很多廣告商的廣告都這樣),頁面不顯示廣告問題在哪里呢? 問題就在這個document.write。為什么?先w3schools看看document.write的定義很使用吧。

定義和用法
write() 方法可向文檔寫入 HTML 表達式或 JavaScript 代碼。
可列出多個參數(shù)(exp1,exp2,exp3,...) ,它們將按順序被追加到文檔中。

方法:
一是在使用該方在文檔中輸出 HTML,另一種是在調(diào)用該方法的的窗口之外的窗口、框架中產(chǎn)生新文檔。在第二種情況中,請務(wù)必使用 close() 方法來關(guān)閉文檔。

但其原理是在頁面流輸入過程中執(zhí)行,一旦頁面加載完畢,再次調(diào)用 document.write(),會隱式地調(diào)用 document.open() 來擦除當前文檔并開始一個新的文檔。也就是說如果在HTML加載完后我們再使用document.write會檫除之前生成html,而顯示document.write輸出的內(nèi)容。

而我們例子中在頁面加載完后在在html中輸出document.write,就不會被執(zhí)行了。問題知道了,原理知道了,那怎么解決這個問題呢?

異步利用ajax,行不同,很多廣告文件都是第三方的,在不同域名下,存在跨域問題,而且不能我們控制其代碼的輸出。在這種情況下我們想到了一個辦法就是重寫掉document.write,在js文件加載結(jié)束后再把document.write重寫回去。看代碼。

***版本無阻塞加載js廣告:

  1. function LoadADScript(url, container, callback){  
  2.         this.dw = document.write;  
  3.         this.url = url;  
  4.         this.containerObj = (typeof container == 'string'?document.getElementById(container):container);  
  5.         this.callback = callback || function(){};  
  6.     }  
  7.       
  8.     LoadADScript.prototype = {  
  9.         startLoad: function(){  
  10.             var script = document.createElement('script'),  
  11.                 _this = this;  
  12.               
  13.             if(script.readyState){ //IE  
  14.                 script.onreadystatechange = function(){  
  15.                 if (script.readyState == "loaded" || script.readyState == "complete"){  
  16.                     script.onreadystatechange = null;  
  17.                     _this.finished();  
  18.                 }  
  19.             };  
  20.             }else//Other  
  21.                 script.onload = function(){  
  22.                     _this.finished();  
  23.                 };  
  24.             }  
  25.               
  26.             document.write = function(ad){  
  27.                 var html = _this.containerObj.innerHTML;  
  28.                 _this.containerObj.innerHTML = html + ad;  
  29.             }  
  30.               
  31.             script.src = _this.url;  
  32.             script.type = 'text/javascript';  
  33.             document.getElementsByTagName('head')[0].appendChild(script);  
  34.         },  
  35.         finished: function(){  
  36.             document.write = this.dw;  
  37.             this.callback.apply();  
  38.         }  
  39.     }; 

頁面調(diào)用代碼:

  1. var loadScript = new LoadADScript('ad.js','msat-adwrap',function(){ console.log('msat-adwrap'); });  
  2. loadScript.startLoad();  
  3.       
  4. var loadScript = new LoadADScript('ad2.js','msat-adwrap',function(){ console.log('msat-adwrap2'); });  
  5. loadScript.startLoad();  
  6.       
  7. var loadScript = new LoadADScript('ad3.js','msat-adwrap',function(){ console.log('msat-adwrap3'); });  
  8. loadScript.startLoad(); 

廣告JS代碼

  1. //ad.js  
  2. document.write('<img src="http://images.cnblogs.com/logo_small.gif" alt="Logo">');  
  3.  
  4. //ad2.js  
  5. document.write('<img src="http://www.baidu.com/img/baidu_sylogo1.gif" width="270" height="129" usemap="#mp">');  
  6.  
  7. //ad3.js  
  8. document.write('<img alt="Google" height="95" id="hplogo" src="http://www.google.com/images/srpr/logo3w.png" width="275">'); 

***版本的問題是在多個文件調(diào)用的時候,會出現(xiàn)一些問題:

1. 由于文件加載的速度不一樣,導致可能有些先加載有些后加載,也就是無序的,而且很多時候我們需要的是有序的。比如我們需要先加載***屏的廣告。

2. 想有些廣告需要前置設(shè)置一些參數(shù)的,例如google adsense

 

為了解決這兩個問題好進一步修改成最終無阻塞加載js版本。

HTML頁面代碼:

  1. <!DOCTYPE html>  
  2. <html lang="en">  
  3.     <head>  
  4.         <meta charset="utf-8" />  
  5.         <title>new_file</title>  
  6.         <script type="text/javascript" src="loadscript.js"></script>  
  7.     </head>  
  8. <body>  
  9. <div id = "msat-adwrap"></div>  
  10. <div id = "msat-adwrap2"></div>  
  11. <script type="text/javascript">  
  12.     loadScript.add({  
  13.         url:'ad.js',  
  14.         container: 'msat-adwrap',  
  15.         callback:function(){ console.log('msat-adwrap'); }  
  16.     }).add({  
  17.         url:'ad2.js',  
  18.         container: 'msat-adwrap2',  
  19.         callback:function(){ console.log('msat-adwrap2'); }  
  20.     }).add({//google adsense  
  21.         url:'http://pagead2.googlesyndication.com/pagead/show_ads.js',  
  22.         container: 'msat-adwrap',  
  23.         init: function(){  
  24.             google_ad_client = "ca-pub-2152294856721899";  
  25.             /* 250x250 rich */ 
  26.             google_ad_slot = "3929903770";  
  27.             google_ad_width = 250;  
  28.             google_ad_height = 250;  
  29.         },  
  30.         callback:function(){ console.log('msat-adwrap3'); }  
  31.     }).execute();  
  32. </script>  
  33. </body>  
  34. </html> 

loadscript.js源代碼

  1. /**  
  2.  * 無阻塞加載廣告  
  3.  * @author Arain.Yu  
  4.  */ 
  5.  
  6. var loadScript = ( function() {  
  7.     var adQueue = [], dw = document.write;  
  8.     //緩存js自身的document.write  
  9.  
  10.     function LoadADScript(url, container, init, callback) {  
  11.         this.url = url;  
  12.         this.containerObj = ( typeof container == 'string' ? document.getElementById(container) : container);  
  13.         this.init = init ||  
  14.         function() {  
  15.         };  
  16.  
  17.         this.callback = callback ||  
  18.         function() {  
  19.         };  
  20.  
  21.     }  
  22.  
  23.     LoadADScript.prototype = {  
  24.         startLoad : function() {  
  25.             var script = document.createElement('script'), _this = this;  
  26.  
  27.             _this.init.apply();  
  28.  
  29.             if(script.readyState) {//IE  
  30.                 script.onreadystatechange = function() {  
  31.                     if(script.readyState == "loaded" || script.readyState == "complete") {  
  32.                         script.onreadystatechange = null;  
  33.                         _this.startNext();  
  34.                     }  
  35.                 };  
  36.             } else {//Other  
  37.                 script.onload = function() {  
  38.                     _this.startNext();  
  39.                 };  
  40.             }  
  41.             //重寫document.write  
  42.             document.write = function(ad) {  
  43.                 var html = _this.containerObj.innerHTML;  
  44.                 _this.containerObj.innerHTML = html + ad;  
  45.             }  
  46.  
  47.             script.src = _this.url;  
  48.             script.type = 'text/javascript';  
  49.             document.getElementsByTagName('head')[0].appendChild(script);  
  50.         },  
  51.         finished : function() {  
  52.             //還原document.write  
  53.             document.write = this.dw;  
  54.         },  
  55.         startNext : function() {  
  56.             adQueue.shift();  
  57.             this.callback.apply();  
  58.             if(adQueue.length > 0) {  
  59.                 adQueue[0].startLoad();  
  60.             } else {  
  61.                 this.finished();  
  62.             }  
  63.         }  
  64.     };  
  65.  
  66.     return {  
  67.         add : function(adObj) {  
  68.             if(!adObj)  
  69.                 return;  
  70.  
  71.             adQueue.push(new LoadADScript(adObj.url, adObj.container, adObj.init, adObj.callback));  
  72.             return this;  
  73.         },  
  74.         execute : function() {  
  75.             if(adQueue.length > 0) {  
  76.                 adQueue[0].startLoad();  
  77.             }  
  78.         }  
  79.     };  
  80. }()); 

原文鏈接:http://www.cnblogs.com/hongcaomao/archive/2012/03/27/javascript_loadad.html

【編輯推薦】

  1. 5種JavaScript調(diào)用函數(shù)的方法
  2. 10件有關(guān)JavaScript讓人費解的事情
  3. 面向?qū)ο蟮腏avaScript基本知識指南大全
  4. 是時候開始使用JavaScript嚴格模式了
  5. 好用的高質(zhì)量JavaScript庫一覽
責任編輯:林師授 來源: 紅草帽的博客
相關(guān)推薦

2014-10-09 09:48:14

JavaScript

2014-11-05 10:31:28

2014-10-10 14:00:52

JavascriptHTML

2009-06-30 15:19:00

阻塞讀取遠程文件Java多線程

2010-01-07 17:03:31

千兆路由交換機

2010-01-11 09:30:39

千兆路由交換機技術(shù)

2021-06-04 18:14:15

阻塞非阻塞tcp

2013-08-22 10:39:03

VOD網(wǎng)絡(luò)建設(shè)VOD網(wǎng)絡(luò)華為

2015-04-30 12:34:05

WordPressNode.js

2016-12-01 09:24:56

Android

2011-07-28 14:29:45

JavaScript

2017-04-12 10:02:21

Java阻塞隊列原理分析

2024-12-20 07:30:00

重定向服務(wù)器端指令Next.js

2010-04-30 09:45:05

廣告木馬網(wǎng)絡(luò)安全卡巴斯基

2021-09-16 05:32:31

No.js 模塊加載器module1.js

2012-12-28 14:23:12

Android開發(fā)TextView

2018-04-18 14:38:14

廣告

2009-12-30 15:26:02

Silverlight

2011-04-25 11:05:10

javascript

2022-04-21 07:52:08

JS線程GUI渲染
點贊
收藏

51CTO技術(shù)棧公眾號

日本女人高潮视频| 国产精品稀缺呦系列在线| 一级黄色电影片| 美女的胸无遮挡在线观看| 91在线视频免费91| 国产精品视频网| 久草资源在线视频| 亚洲婷婷丁香| 91精品国产一区二区三区| 黄色一级片在线看| av影片在线看| 成人美女在线视频| 国产精品亚洲激情| 欧美一级高潮片| 成人羞羞网站入口| 精品av久久707| 亚洲 国产 图片| 国产高清视频色在线www| 国产精品久久毛片| 国偷自产av一区二区三区小尤奈| 伊人久久国产精品| 亚洲影视在线| 色综合久久久888| 国产无遮挡在线观看| 国产精品视屏| 这里只有精品99re| 欧美性猛交xxx乱久交| 日本精品600av| 国产精品进线69影院| 鲁片一区二区三区| www.国产黄色| 麻豆精品一区二区| 国产成人高清激情视频在线观看| 久久免费视频播放| 国产精品精品| 在线精品播放av| 国产ts在线播放| 黄色欧美在线| 精品美女一区二区| 在线免费黄色小视频| 在线观看污视频| 在线免费观看一区二区| 久久精品首页| 欧美孕妇孕交黑巨大网站| 久久久久久久久艹| 在线精品国产| 久久精品人人做人人爽| 久久久精品成人| 欧美精品尤物在线观看| 日韩h在线观看| 一级国产黄色片| 色先锋久久影院av| 日韩av网址在线| free性中国hd国语露脸| 国产精品久久久久av蜜臀| 日韩欧美高清dvd碟片| 真实乱偷全部视频| 无码国模国产在线观看| 日韩久久精品一区| 国产在线a视频| 永久免费精品视频| 精品国产一二三区| 精品熟女一区二区三区| 人妖一区二区三区| 亚洲精品一区二区三区不| 免费a级黄色片| 九色成人国产蝌蚪91| 日韩国产高清污视频在线观看| 亚洲激情 欧美| 波多野结衣理论片| 日本免费一区二区六区| 午夜伦理一区二区| 欧美日韩在线视频一区二区三区| 综合久久2023| 欧美日韩一区小说| aaa一级黄色片| 一区二区三区在线免费看| 精品国产露脸精彩对白| 日本黄色网址大全| 成人精品电影| 欧美另类极品videosbest最新版本| 久久丫精品久久丫| 一本不卡影院| 国产精品高潮视频| 国产精品久久久久久免费播放| 国产乱子轮精品视频| 粉嫩av免费一区二区三区| 无码精品一区二区三区在线| 国产婷婷一区二区| 久久观看最新视频| 极品在线视频| 欧美三级电影网| 日本xxxx免费| 一区二区三区韩国免费中文网站| 深夜精品寂寞黄网站在线观看| 在线免费观看亚洲视频| 蜜桃视频一区| 亚洲直播在线一区| 欧美午夜黄色| 亚洲你懂的在线视频| 欧美在线观看www| 五月天色综合| 亚洲摸下面视频| 波多野结衣家庭教师| 99日韩精品| 亚洲一区免费网站| 国产黄色在线| 一区二区三区欧美亚洲| 美女网站免费观看视频| 97se亚洲国产一区二区三区| 一区二区在线视频| 日韩美女一级片| 国模少妇一区二区三区| 欧美精品中文字幕一区二区| 2024最新电影免费在线观看| 色综合久久99| 91porn在线| 性欧美欧美巨大69| 日韩男女性生活视频| 国产综合在线播放| 亚洲女爱视频在线| 狠狠躁狠狠躁视频专区| 日韩大尺度在线观看| 久久91亚洲精品中文字幕| 久久这里只有精品9| 不卡区在线中文字幕| 中文字幕免费高| 成人国产精品一区二区免费麻豆 | 国内精品伊人| 亚洲国产精品大全| 欧美精品久久久久性色| 久久激情五月激情| 日韩在线电影一区| 不卡一二三区| 精品无人区乱码1区2区3区在线| 免费在线观看亚洲| 国产在线精品免费| 亚洲欧洲三级| 激情中国色综合| 国产亚洲综合久久| 日韩在线视频不卡| 久久蜜桃av一区精品变态类天堂| www.99热这里只有精品| 8x国产一区二区三区精品推荐| 久久手机免费视频| 一级特黄aaa大片在线观看| 日本一区二区三区四区| aaa毛片在线观看| 自拍偷拍欧美日韩| 色婷婷久久av| 国产精品爽爽久久久久久| 国产精品久久毛片av大全日韩| 搡女人真爽免费午夜网站| 国产成人一区| 国产精品丝袜白浆摸在线| 自拍视频在线播放| 欧美二区乱c少妇| 神马午夜精品91| 国产一区二区调教| 一区二区三视频| www.欧美| 久久久久久香蕉网| 五月婷中文字幕| 色综合久久综合网欧美综合网| 黄色正能量网站| 日日夜夜一区二区| 亚洲欧美成人一区| 国产精品美女久久久久人| 欧美日韩国产91| 六月婷婷综合网| 狠狠爱在线视频一区| 中文字幕网站在线观看| 男女男精品网站| 妞干网这里只有精品| 超碰成人在线免费| 4p变态网欧美系列| www.成人.com| 日韩欧美视频一区| 中文字幕免费在线观看视频| 国产喷白浆一区二区三区| 亚洲午夜精品一区| 亚洲精品极品| 四虎永久国产精品| 精品中文字幕一区二区三区| 午夜精品久久久99热福利| 黑人与亚洲人色ⅹvideos| 欧美精品一卡二卡| 精品无码久久久久久久| 日本一区二区免费在线观看视频| 黄色三级视频在线播放| 狠久久av成人天堂| 日本在线观看一区二区| 秋霞午夜一区二区三区视频| 91av在线网站| 黄色免费在线看| 亚洲精品mp4| 91欧美日韩麻豆精品| 亚洲国产日韩在线一区模特| 99精品欧美一区二区| 福利一区二区在线| 不卡av免费在线| 亚洲精品激情| 国产盗摄视频在线观看| 欧美美女在线| 成人欧美一区二区三区在线观看| 欧美最新精品| 国模极品一区二区三区| 最新真实国产在线视频| 日韩高清欧美高清| 精品人妻久久久久一区二区三区 | 精品视频成人| 2019中文字幕免费视频| 国产精品一卡二卡三卡| 国产午夜一区二区| 香蕉视频黄色片| 欧美一级欧美三级在线观看| 不卡av电影在线| 亚洲国产一区二区在线播放| 美女福利视频网| 久久久亚洲国产美女国产盗摄 | 国产一区二区三区免费在线| 日产日韩在线亚洲欧美| 蜜臀av在线| 久久综合五月天| 日韩大片在线永久免费观看网站| 日韩精品中文字幕视频在线| 亚洲第一免费视频| 69堂成人精品免费视频| 乱子伦一区二区三区| 黑人极品videos精品欧美裸| 久久国产在线视频| 亚洲品质自拍视频| 亚洲天堂最新地址| 国产亚洲成av人在线观看导航 | 国产美女无遮挡永久免费| 色综合一区二区| 欧美不卡视频在线观看| 亚洲一级片在线观看| wwwav国产| 亚洲免费在线观看| 日韩av手机在线免费观看| 国产精品日日摸夜夜摸av| 性欧美精品中出| 国产调教视频一区| 日本精品在线观看视频| 久久久激情视频| 97超碰在线资源| 久久精品无码一区二区三区| 国产全是老熟女太爽了| 久久理论电影网| 日本少妇高潮喷水xxxxxxx| 2024国产精品| 91中文字幕永久在线| 成人精品视频一区二区三区| 欧美丰满熟妇bbb久久久| 成人午夜视频免费看| 欧美日韩一区二区三区四区五区六区| 国产91露脸合集magnet| 91九色蝌蚪porny| 99久久精品国产一区| 亚洲欧美视频在线播放| 久久久久久久久免费| 极品尤物一区二区| 亚洲人成伊人成综合网小说| 欧美日韩精品一区二区三区视频播放| 一区二区三区蜜桃| 日本特黄特色aaa大片免费| 精品久久久国产精品999| 亚洲欧美日韩激情| 欧美日韩一区二区三区四区五区 | 免费在线国产精品| 成人短片线上看| 亚洲欧美一二三| 一区在线播放| 日韩精品一区中文字幕| 蜜桃av噜噜一区| 在线免费黄色小视频| av亚洲精华国产精华精华| asian性开放少妇pics| 国产精品乱码人人做人人爱 | 国产免费av在线| 爱福利视频一区| 1区2区3区在线| 国产精品大陆在线观看| www.久久爱.com| 精品国产乱码久久久久久蜜柚| 国产一区二区三区网| 好色先生视频污| 久久久久综合| www.久久com| 久久日韩粉嫩一区二区三区| 91香蕉一区二区三区在线观看| 亚洲综合男人的天堂| 免费黄色小视频在线观看| 欧美一级搡bbbb搡bbbb| 四虎电影院在线观看| www.亚洲免费视频| 女厕盗摄一区二区三区| 成人在线中文字幕| 亚洲欧美日本伦理| 青青在线免费视频| 久久久成人网| 91九色蝌蚪porny| 亚洲欧洲日本在线| 国产原创视频在线| 日韩免费看网站| 1pondo在线播放免费| 97精品一区二区三区| 国产一区二区av在线| 奇米精品在线| 亚洲精品九九| 性生活一级大片| 国产精品无人区| 久久夜色精品国产噜噜亚洲av| 91精品国产福利| fc2在线中文字幕| 欧美中文在线观看国产| 一区二区亚洲视频| 男人的天堂成人| 免费看黄色91| 亚洲区自拍偷拍| 午夜电影网一区| 亚洲a视频在线观看| 日韩亚洲精品视频| 素人啪啪色综合| 日韩福利在线| 久久免费黄色| 懂色av粉嫩av蜜乳av| 亚洲第一激情av| 乱色精品无码一区二区国产盗| 久久综合伊人77777蜜臀| а√天堂资源国产精品| 日韩国产一区久久| 老鸭窝毛片一区二区三区| 韩国无码一区二区三区精品| 亚洲最新在线观看| 国产黄a三级三级看三级| 日韩一区二区在线视频| 亚州精品国产| 大桥未久一区二区| 韩国女主播成人在线| 天天鲁一鲁摸一摸爽一爽| 欧美日韩国产小视频在线观看| 牛牛澡牛牛爽一区二区| 日本在线精品视频| 国产欧美日韩| 五月天婷婷激情视频| 国产日韩精品久久久| 久久人人爽人人爽人人片av免费| 亚洲美女在线视频| 欧美日韩免费看片| 日韩精品国内| 美女精品一区二区| 糖心vlog免费在线观看| 91精品国产色综合久久不卡电影| 黄网站在线免费| 97国产超碰| 亚洲精品1234| 色婷婷av777| 欧美亚洲日本一区| 免费在线你懂的| 亚洲自拍偷拍在线| 在线不卡欧美| 亚洲自拍偷拍一区二区| 欧美亚洲国产一区二区三区va| 99视频在线观看地址| 亚洲a在线观看| 亚洲精品社区| 国产一级久久久久毛片精品| 欧美精品乱码久久久久久| 福利视频在线| 久久成人资源| 免费在线观看成人| 青娱乐国产在线视频| 亚洲黄色有码视频| 日韩免费小视频| 97超碰人人爱| 92国产精品观看| 岳乳丰满一区二区三区| 欧美成人自拍视频| 欧美一性一交| 久久久久久蜜桃一区二区| 一卡二卡三卡日韩欧美| 欧美日韩在线精品一区二区三区激情综 | 免费观看性欧美大片无片| 喜爱夜蒲2在线| 93久久精品日日躁夜夜躁欧美| 亚洲 欧美 成人| 久久亚洲精品毛片| 五月国产精品| 911福利视频| 婷婷综合五月天| 1769视频在线播放免费观看| 国产一区二区黄色| 男女性色大片免费观看一区二区| 国产一级特黄视频| 丝袜亚洲欧美日韩综合| 群体交乱之放荡娇妻一区二区| 国产精品嫩草影院8vv8| 五月婷婷综合网|