亚洲av日韩av永久无码久久,免费的视频app网站,欧美性猛交xxxx免费看,国产成人精品三级麻豆

JavaScript 事件對內(nèi)存和性能的影響

2016-9-23    藍(lán)藍(lán)設(shè)計的小編

如果您想訂閱本博客內(nèi)容,每天自動發(fā)到您的郵箱中, 請點(diǎn)這里 

 

雖說事件處理程序可以為現(xiàn)代 Web 頁面添加很強(qiáng)的交互能力,但是不分青紅皂白就添加大量的事件處理程序絕對是一種愚蠢的行為。

我們來分析一下:事件處理程序本質(zhì)上是一種函數(shù),是一種對象,存放在內(nèi)存中,設(shè)置大量的事件處理程序會使內(nèi)存中的對象變多,Web 程序的性能會變得越來越差,用戶體驗(yàn)很不好。

為了更好地利用好事件處理程序,便出現(xiàn)了事件委托,用來提升性能。

事件委托

事件委托(event delegation):把若干個子節(jié)點(diǎn)上的相同事件的處理函數(shù)綁定到它的父節(jié)點(diǎn)上去,在父節(jié)點(diǎn)上統(tǒng)一處理從子節(jié)點(diǎn)冒泡上來的事件,這種技術(shù)就叫做事件委托。

補(bǔ)充一下:事件委托并不局限于父節(jié)點(diǎn)與子節(jié)點(diǎn)之間。也可以這樣玩,比如頁面文檔中有好多個處在不同位置地 button,都是綁定 click 事件,使用事件委托,我們可以把這些個事件統(tǒng)一綁定到 body 元素,然后再進(jìn)行處理(雖然一般很少這么用)。

下面舉例子逐步說明事件委托的優(yōu)勢:

<ul id="parent-list"> <li id="list-1">List 1</li> <li id="list-2">List 2</li> <li id="list-3">List 3</li> <li id="list-4">List 4</li> <li id="list-5">List 5</li> </ul>

假設(shè)有上面的代碼,我們現(xiàn)在有一個需求:就是無論單擊上面的列表(ul)的哪個子列表(li),都會彈出一個框,來顯示我們點(diǎn)擊了哪個子列表。

需求不難吧?有了需求,接下來是該寫 js 代碼了,現(xiàn)在有兩種方法放在你眼前:1. 為每個 li 子元素綁定 click 事件,然后設(shè)置處理函數(shù); 2. 利用事件委托,為 ul 父元素綁定 click 事件,然后設(shè)置處理函數(shù)

// 方法一 var list1 = document.getElementById("list-1");
list1.addEventListener("click",function(){
  alert(this.firstChild.nodeValue);
},false); var list2 = document.getElementById("list-2");
list2.addEventListener("click", function() {
  alert(this.firstChild.nodeValue);
}, false); var list3 = document.getElementById("list-3");
list3.addEventListener("click", function() {
  alert(this.firstChild.nodeValue);
}, false); var list4 = document.getElementById("list-4");
list4.addEventListener("click", function() {
  alert(this.firstChild.nodeValue);
}, false); var list5 = document.getElementById("list-5");
list5.addEventListener("click", function() {
  alert(this.firstChild.nodeValue);
}, false);
// 方法二 var parentList = document.getElementById("parent-list");
parentList.addEventListener("click",function(){ var target = event.target; if(target.nodeName.toLowerCase() === "li"){
    alert(target.firstChild.nodeValue);
  }
},false);

看著上面的代碼,我這里寫幾點(diǎn)方法二的優(yōu)點(diǎn):1. 減少了訪問 DOM 的次數(shù),提升了性能;2. 將子元素的事件處理程序統(tǒng)一綁定到其父元素,減少了對內(nèi)存的占用;3. 可以更好地管理事件處理程序,比如移除對某個事件處理程序的引用

注意:如果對各個子元素的需求不一樣,我們還可以這樣來改寫上面的方法二:

// 方法二 var parentList = document.getElementById("parent-list");
parentList.addEventListener("click",function(){ var target = event.target; if(target.nodeName.toLowerCase() === "li"){ switch(target.id){ case "list-1":
        alert("學(xué)的越多,越覺得自己無知!"); break; case "list-2":
        alert("愛是一種藝術(shù)!"); break; case "list-3":
        target.innerHTML = "呵呵,我改了?。?; break; case "list-4":
        target.style.background = "#aaa"; break; case "list-5":
        target.style.color = "red";
        target.style.fontSize = "2em"; break; default: break;
    }
  }
},false);

因?yàn)槭录幸蕾囀录芭輽C(jī)制,所以,并不是所有的事件都可以進(jìn)行事件委托。

最適合采用事件委托的事件包括:click、mousedown、mouseup、keydown、keyup 和 keypress。

事件委托只是一種非常不錯的事件綁定的思想,所以不應(yīng)該拘泥于上面的例子,要活學(xué)活用! ^_^

移除事件處理程序

我們前面說過,事件處理程序存在于內(nèi)存中,每當(dāng)將事件處理程序指定給元素時,運(yùn)行中的瀏覽器代碼與支持頁面交互的 JavaScript 代碼之間就會建立一個連接。這種連接越多,頁面執(zhí)行就越慢。前面所說的事件委托就是用來限制建立的連接數(shù)量。

還有,就是內(nèi)存中那些使用完后不再使用的事件處理程序,如果不釋放掉,也會影響 Web 應(yīng)用程序的內(nèi)存和性能。

<button id="button">提交</button> var button = document.getElementById("button");
button.onclick = function(){ // 提交某個表單的操作代碼 button.onclick = null; // 移除事件處理程序 event.target.firstChild.nodeValue = "提交中。。。";
};

總的原則就是:移除掉那些過時不再使用的事件處理程序,釋放內(nèi)存!

 

藍(lán)藍(lán)設(shè)計www.chinatradebeam.com )是一家專注而深入的界面設(shè)計公司,為期望卓越的國內(nèi)外企業(yè)提供卓越的UI界面設(shè)計、BS界面設(shè)計 、 cs界面設(shè)計 、 ipad界面設(shè)計 、 包裝設(shè)計 、 圖標(biāo)定制 、 用戶體驗(yàn) 、交互設(shè)計、 網(wǎng)站建設(shè) 、平面設(shè)計服務(wù) 

 

日歷

鏈接

個人資料

藍(lán)藍(lán)設(shè)計的小編 http://www.chinatradebeam.com

存檔

粗大的内捧猛烈进出a片| 天堂8在线天堂资源bt| 偷拍真实夫妇作爱视频| 亚洲AV区无码字幕中文色| 刺激的至亲乱45部| 全职法师第6季全集免费观看| 国产99久久久国产精品~~牛 | 被黑人伦流澡到高潮hnp动漫| 国产色情一区二区视频| 色偷偷噜噜噜亚洲男人| 麻豆亚洲av熟女国产一区二| 亚洲综合AV一区二区三区| 人妻另类 专区 欧美 制服| 日日婷婷夜日日天干a片| 久久精品99国产精品日本| 国产重口老太和小伙a片| jizz日本| 丁香激情综合久久伊人久久| 国产精品久久久久久AV| 无码国产69精品久久久久网站| 日韩欧美激情免费a片影院卜| 粗大的内捧猛烈进出| 亚洲精品乱码久久久久久自慰| 女人下边紧了好还是松点好| 97久久精品亚洲中文字幕无码| 色欲av无码一区二区三区| 99精品人妻无码专区在线视频区| 老头把舌头伸进粉嫩淑芬| 精品国产制服丝袜高跟| 丁香花在线影院观看在线播放| 久久精品国产亚洲av嫖农村妇女| a片在线播放| 美女露?0的奶头无挡挡| 色欲久久99精品久久久久久av| 亚洲AV无码精品色午夜果冻不| 中文av人妻av无码中文视频| 日本无码成人片在线观看波多| 久久综合亚洲色hezyo国产| 亚洲色丰满少妇高潮18p| 中文字幕无码精品亚洲资源网久久| 免费a级毛片无码免费视频|