成人无码视频,亚洲精品久久久久av无码,午夜精品久久久久久毛片,亚洲 中文字幕 日韩 无码

資訊專欄INFORMATION COLUMN

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

Ajian / 2294人閱讀

摘要:事件對(duì)內(nèi)存和性能的影響雖說(shuō)事件處理程序可以為現(xiàn)代頁(yè)面添加很強(qiáng)的交互能力,但是不分青紅皂白就添加大量的事件處理程序絕對(duì)是一種愚蠢的行為。最適合采用事件委托的事件包括和。提交提交某個(gè)表單的操作代碼移除事件處理程序提交中。。。

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

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

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

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

事件委托

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

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

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

  • List 1
  • List 2
  • List 3
  • List 4
  • List 5

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

需求不難吧?有了需求,接下來(lái)是該寫 js 代碼了,現(xiàn)在有兩種方法放在你眼前:1. 為每個(gè) 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. 減少了訪問(wèn) DOM 的次數(shù),提升了性能;2. 將子元素的事件處理程序統(tǒng)一綁定到其父元素,減少了對(duì)內(nèi)存的占用;3. 可以更好地管理事件處理程序,比如移除對(duì)某個(gè)事件處理程序的引用

注意:如果對(duì)各個(gè)子元素的需求不一樣,我們還可以這樣來(lái)改寫上面的方法二:

// 方法二
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é)的越多,越覺(jué)得自己無(wú)知!");
        break;
      case "list-2":
        alert("愛(ài)是一種藝術(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。

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

移除事件處理程序

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

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



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

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

參考資料

【書】《JavaScript 高級(jí)程序設(shè)計(jì)(第三版)》

【文章】2016前端面試題之手寫事件模型及事件代理/委托(推薦)

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.hztianpu.com/yun/80571.html

相關(guān)文章

  • redis過(guò)期鍵刪除策略

    摘要:定時(shí)刪除在設(shè)置鍵的過(guò)期時(shí)間的同時(shí),創(chuàng)建一個(gè),讓定時(shí)器在鍵的過(guò)期時(shí)間到達(dá)時(shí),立即執(zhí)行對(duì)鍵的刪除操作。主動(dòng)刪除對(duì)內(nèi)存友好,但是對(duì)時(shí)間不友好,有較多過(guò)期鍵的而情況下,刪除過(guò)期鍵會(huì)占用相當(dāng)一部分時(shí)間。 1.定時(shí)刪除:在設(shè)置鍵的過(guò)期時(shí)間的同時(shí),創(chuàng)建一個(gè)timer,讓定時(shí)器在鍵的過(guò)期時(shí)間到達(dá)時(shí),立即執(zhí)行對(duì)鍵的刪除操作。(主動(dòng)刪除)對(duì)內(nèi)存友好,但是對(duì)cpu時(shí)間不友好,有較多過(guò)期鍵的而情況下,刪除過(guò)期...

    canger 評(píng)論0 收藏0
  • 使用XHProf查找PHP性能瓶頸

    摘要:是開(kāi)發(fā)的一個(gè)測(cè)試性能的擴(kuò)展,本文記錄了在應(yīng)用中使用對(duì)進(jìn)行性能優(yōu)化,查找性能瓶頸的方法。函數(shù)用于停止性能分析,并返回分析的數(shù)據(jù)。該參數(shù)用于為剖析結(jié)果添加額外的信息,該參數(shù)的值使用以下宏,如果需要提供多個(gè)值,使用進(jìn)行分隔。 XHProf是facebook 開(kāi)發(fā)的一個(gè)測(cè)試php性能的擴(kuò)展,本文記錄了在PHP應(yīng)用中使用XHProf對(duì)PHP進(jìn)行性能優(yōu)化,查找性能瓶頸的方法。 安裝Xhprof擴(kuò)展...

    Xufc 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<