92国产精品视频_亚洲a级在线观看_国产精品电影观看_国产精品免费观看在线_精品伊人久久97_亚洲人成在线观_尤物九九久久国产精品的特点_成人激情在线播放_成人黄色大片在线免费观看_亚洲成人精品久久久_久久免费视频在线观看_久久精品国产一区_国产一区二区三区18_亚洲欧美中文字幕在线一区_日韩美女中文字幕_日韩视频免费在线

JavaScript 事件對內存和性能的影響

2016-9-23    藍藍設計的小編

如果您想訂閱本博客內容,每天自動發到您的郵箱中, 請點這里 

 

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

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

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

事件委托

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

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

下面舉例子逐步說明事件委托的優勢:

<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>

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

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

// 方法一 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);

看著上面的代碼,我這里寫幾點方法二的優點:1. 減少了訪問 DOM 的次數,提升了性能;2. 將子元素的事件處理程序統一綁定到其父元素,減少了對內存的占用;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("學的越多,越覺得自己無知!"); break; case "list-2":
        alert("愛是一種藝術!"); 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);

因為事件委托依賴事件冒泡機制,所以,并不是所有的事件都可以進行事件委托。

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

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

移除事件處理程序

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

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

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

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

 

藍藍設計m.skdbbs.com )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 、平面設計服務 

 

日歷

鏈接

個人資料

藍藍設計的小編 http://m.skdbbs.com

存檔

92国产精品视频_亚洲a级在线观看_国产精品电影观看_国产精品免费观看在线_精品伊人久久97_亚洲人成在线观_尤物九九久久国产精品的特点_成人激情在线播放_成人黄色大片在线免费观看_亚洲成人精品久久久_久久免费视频在线观看_久久精品国产一区_国产一区二区三区18_亚洲欧美中文字幕在线一区_日韩美女中文字幕_日韩视频免费在线
国产电影一区二区在线观看| 亚洲人成网在线播放| 日本精品一区二区三区高清 久久| 日产精品高清视频免费| 国产精品视频资源| 欧美另类视频在线| 台湾亚洲精品一区二区tv| 欧美日韩久久精品| 欧美aaaaaaaaaaaa| 国产福利久久精品| 亚洲精品亚洲人成人网在线播放| av电影一区| 影音先锋成人在线电影| 国产精品9999久久久久仙踪林| 亚洲毛片av在线| 99久久99久久精品国产片果冻| 久久久久久久久岛国免费| 欧美日韩一区二区在线| 日韩激情视频在线| 偷拍视频一区二区| 精品国产一区一区二区三亚瑟| 国产日韩精品一区| 成人欧美一区二区三区黑人孕妇| 国产自产女人91一区在线观看| 国产午夜精品久久久久免费视| 奇米影视一区二区三区| 蜜桃视频成人m3u8| 国产精品自拍毛片| 精品第一国产综合精品aⅴ| 性色av一区二区咪爱| 亚洲.国产.中文慕字在线| 2019年精品视频自拍| 久久久蜜桃精品| 人人视频精品| 国产精品久久久久久久久免费相片| 久久精品视频在线| 麻豆国产一区二区| 亚洲一区二区三区四区五区中文| 日本不卡的三区四区五区| 国产亚洲一区二区三区四区| 久久99深爱久久99精品| 精品av导航| 色女孩综合网| 国产免费av国片精品草莓男男| 亚洲精品大全| 日韩亚洲国产中文字幕欧美| 国产女同性恋一区二区| 午夜影院在线观看欧美| 国产有色视频色综合| 激情亚洲另类图片区小说区| 日韩av免费看| 成人豆花视频| 99亚洲乱人伦aⅴ精品| 日本精品免费观看| 日韩免费在线看| 国产在线不卡精品| 国产精品久久久久久久久动漫| av免费不卡国产观看| 欧美成人精品h版在线观看| 狼人精品一区二区三区在线| 国产在线欧美日韩| 亚洲美女精品成人在线视频| 日韩一区二区三区免费播放| 久久久av水蜜桃| 欧美黄色三级网站| 日本高清不卡一区| av片在线观看网站| 懂色一区二区三区| 亚洲黄色天堂| 中文字幕一区二区三区四区| 啄木系列成人av电影| 国产精品大尺度| 香蕉久久夜色精品国产更新时间| 粉嫩绯色av一区二区在线观看| 国产成人免费9x9x人网站视频| 欧美成人亚洲成人| 国产亚洲精品成人av久久ww| 亚洲高清在线观看| crdy在线观看欧美| 国产精品sss| 国产99久久精品| 国产精品女视频| 奇米成人av国产一区二区三区| 无遮挡的视频在线观看| 欧美福利在线播放网址导航| 8x国产一区二区三区精品推荐| 国产精品高清亚洲| 国产成人av在线播放| 日韩欧美中文免费| 91黄页在线观看| 国产精品午夜一区二区欲梦| 蜜桃久久久久久久| 国产精品三级久久久久久电影| 99久久综合狠狠综合久久止| 欧美高清视频在线高清观看mv色露露十八| 一本大道久久a久久综合婷婷| 亚洲3atv精品一区二区三区| 亚洲欧美区自拍先锋| 18视频免费网址在线观看| 久久不射电影网| 一区二区三区蜜桃网| 国产精品女同一区二区三区| 99久久精品国产亚洲精品| 91av视频在线| 色欧美片视频在线观看| 91精品国产色综合久久不卡粉嫩| www.日韩精品| 国产精品久久久久久久小唯西川| 欧美一级一级性生活免费录像| 国产日韩欧美精品| 不卡一卡2卡3卡4卡精品在| 成人在线分类| 日韩av在线高清| 亚洲精品在线免费观看视频| 亚洲va久久| 亚洲性日韩精品一区二区| 国产91一区| 999国产精品永久免费视频app| 夜夜夜精品看看| 欧美亚洲视频在线观看| 91麻豆精品国产91久久久使用方法| 欧美人与z0zoxxxx视频| 涩涩涩久久久成人精品| 一本色道69色精品综合久久| 欧美久久香蕉| 日本在线观看视频| 久久久久久91| 久久国产精品区| 日韩av图片| 久久精品成人欧美大片古装| 国产欧美久久久久久久久| 99久久精品网| 97福利一区二区| 久久久精品一区二区毛片免费看| 亚洲欧洲三级电影| 久久99蜜桃精品| 成人av综合网| 久久精品视频在线免费观看| 国产精品久久99| 日本色综合中文字幕| 韩国精品免费视频| 五月婷婷一区| 欧美日韩亚洲精品内裤| 激情av综合| 最新成人av在线| 精品久久中文字幕久久av| 99免费在线视频观看| 秋霞在线观看一区二区三区| 91久久久久久白丝白浆欲热蜜臀| 亚洲欧美日韩精品| 日韩av手机在线| 欧美一级日韩免费不卡| 亚洲精品久久嫩草网站秘色| 欧美在线视频二区| 2023亚洲男人天堂| 成人午夜精品在线| 国产高清在线| 国产高清视频色在线www| 成人激情直播| www红色一片_亚洲成a人片在线观看_| 国产精品videosex极品| 亚洲大胆美女视频| 欧美一区三区三区高中清蜜桃| 国产一区二区三区站长工具|