99久久精品国产片-99久久精品国产免费-99久久精品国产麻豆-99久久精品国产国产毛片-99久久精品国产高清一区二区-99久久精品费精品国产一区二区

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 = "提交中。。。";
};

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

 

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

 

日歷

鏈接

個人資料

藍藍設計的小編 http://www.lapeinture.cn

存檔

九九精品在线| 韩国三级视频网站| 久久久久久久网| 国产一区免费在线观看| 韩国毛片免费大片| 欧美a级片免费看| 欧美1区| 亚洲精品永久一区| 成人av在线播放| 免费国产一级特黄aa大片在线| 色综合久久天天综合绕观看 | 一级毛片看真人在线视频| 国产一区二区精品| 国产伦久视频免费观看视频| 精品视频一区二区三区免费| 高清一级淫片a级中文字幕| 精品国产一区二区三区久久久狼| 午夜在线影院| 欧美国产日韩一区二区三区| 美女免费毛片| 天堂网中文字幕| 可以免费看污视频的网站| 香蕉视频亚洲一级| 日韩av片免费播放| 高清一级毛片一本到免费观看| 韩国三级视频网站| 久久精品店| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 麻豆午夜视频| 99久久视频| 欧美一区二区三区在线观看| 国产成a人片在线观看视频| 国产精品自拍亚洲| 可以免费看污视频的网站| 日韩免费在线视频| 日日爽天天| 精品视频免费观看| 国产成人啪精品| 中文字幕一区二区三区精彩视频| 欧美日本免费| 夜夜操网| 精品国产一区二区三区精东影业 | 精品视频一区二区三区| 欧美国产日韩一区二区三区| 日韩在线观看视频网站| 精品视频在线观看免费| 美女免费毛片| 日本伦理网站| 国产国语在线播放视频| | 麻豆系列 在线视频| 日本免费乱理伦片在线观看2018| 天天做日日干| 久草免费资源| 欧美一区二区三区在线观看| 国产伦精品一区三区视频| 国产视频一区在线| 色综合久久天天综合| 九九九网站| 日日日夜夜操| 欧美1区2区3区| 精品视频在线看| 久久国产精品永久免费网站| 二级片在线观看| 久久久成人网| 精品视频在线观看视频免费视频| 九九精品在线| 一本高清在线| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 久久国产精品自线拍免费| 四虎影视久久| 日韩在线观看视频黄| 美女免费精品视频在线观看| 可以免费在线看黄的网站| 欧美另类videosbestsex视频| 色综合久久天天综合| 91麻豆精品国产自产在线观看一区| 黄视频网站在线观看| 久久久久久久免费视频| 国产伦精品一区二区三区在线观看| 青青久热| 麻豆网站在线看| 成人av在线播放| 美女免费毛片| 精品国产三级a∨在线观看| 夜夜操天天爽| 在线观看成人网| 中文字幕一区二区三区精彩视频| 日韩一级黄色片| 99久久精品国产麻豆| 九九久久99| 九九九国产| 国产麻豆精品免费视频| 国产一区二区精品久久91| 成人免费一级毛片在线播放视频| 欧美日本免费| 成人高清视频在线观看| 亚洲 激情| 美国一区二区三区| 日本特黄特色aaa大片免费| 四虎影视久久久| 久久成人性色生活片| 国产成人啪精品| 你懂的日韩| 91麻豆精品国产片在线观看| 亚洲天堂免费观看| 国产成人精品影视| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 毛片高清| 国产精品自拍在线观看| 韩国毛片免费大片| 久久国产精品永久免费网站| 夜夜操网| 欧美一级视| 欧美电影免费| 欧美另类videosbestsex高清| 一本高清在线| 日本特黄特黄aaaaa大片| 国产不卡高清| 精品国产一区二区三区国产馆 | 99色视频在线| 久久精品欧美一区二区| 亚洲精品影院一区二区| 欧美国产日韩久久久| 精品国产香蕉在线播出| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 亚洲精品影院久久久久久| 精品久久久久久中文| 高清一级做a爱过程不卡视频| 黄视频网站在线看| 欧美激情伊人| 久久精品店| 999久久66久6只有精品| 精品美女| 欧美电影免费| 国产视频一区二区在线观看| 麻豆系列国产剧在线观看| 九九干| 日韩在线观看免费完整版视频| 99久久精品国产片| 国产成人欧美一区二区三区的| 一级女性大黄生活片免费| 韩国三级香港三级日本三级la| 高清一级毛片一本到免费观看| 中文字幕一区二区三区精彩视频 | 青青青草影院 | 亚州视频一区二区| 日韩免费在线观看视频| 国产伦久视频免费观看视频| 精品视频免费看| 91麻豆国产级在线| 亚洲第一视频在线播放| 一级毛片视频播放| 色综合久久久久综合体桃花网| 台湾美女古装一级毛片| 国产一区二区精品在线观看| 99久久精品国产片| 久久国产精品自由自在| a级黄色毛片免费播放视频| 国产国语在线播放视频| 久久国产影院| 日韩一级黄色片| 精品视频在线观看一区二区三区| 毛片的网站| 亚洲wwwwww| 超级乱淫黄漫画免费| 日韩av东京社区男人的天堂| 国产视频网站在线观看| 日韩av片免费播放| 91麻豆国产级在线| 久久久久久久免费视频| 青青久热| 日本伦理黄色大片在线观看网站| 亚洲第一视频在线播放| 精品国产亚洲一区二区三区| 亚久久伊人精品青青草原2020| 九九精品久久| 欧美激情一区二区三区在线播放| 九九干| 日韩字幕在线| 精品视频在线观看视频免费视频| 亚洲精品影院| 亚飞与亚基在线观看| 国产一区二区精品久久| 免费的黄视频| 国产综合成人观看在线| 欧美激情一区二区三区在线| 999精品视频在线| 日本特黄特黄aaaaa大片| 91麻豆国产级在线| 欧美激情一区二区三区在线播放| 免费国产在线观看| 欧美大片一区| 国产亚洲男人的天堂在线观看| 欧美激情一区二区三区中文字幕| 久久99青青久久99久久| 日韩在线观看视频免费| 免费一级片网站| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 青草国产在线|