亚洲av午夜福利精品一区人妖,亚洲乱码日产精品a级毛片久久,91精品视频观看,青草青草久热精品视频在线观看

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

存檔

亚洲av午夜福利精品一区人妖,亚洲乱码日产精品a级毛片久久,91精品视频观看,青草青草久热精品视频在线观看
<strike id="cy2gs"><menu id="cy2gs"></menu></strike>
  • <del id="cy2gs"><dfn id="cy2gs"></dfn></del>
  • 欧美一级片久久久久久久| 国产丝袜美腿一区二区三区| 伊人精品成人久久综合软件| 国产精品亚洲综合色区韩国| 欧美日韩在线电影| 欧美精品日韩综合在线| 欧美精品一卡二卡| 欧美精品一区在线播放| 欧美高潮视频| 美女尤物久久精品| 免费观看一区| 欧美大片免费看| 欧美大香线蕉线伊人久久国产精品| 麻豆精品91| 欧美freesex8一10精品| 欧美黄色影院| 欧美日韩国语| 欧美午夜视频在线观看| 国产精品欧美激情| 国产视频一区在线观看| 韩国三级电影久久久久久| 国产一区二三区| 在线成人欧美| 亚洲黄网站在线观看| 亚洲精品日韩激情在线电影| 一本色道精品久久一区二区三区 | 欧美日韩在线三区| 国产精品99免视看9| 国产精品视频xxxx| 黑丝一区二区| 亚洲靠逼com| 亚洲欧美成人一区二区在线电影| 欧美在线影院在线视频| 蜜臀av一级做a爰片久久 | 蜜臀91精品一区二区三区| 欧美精品激情| 国产精品系列在线播放| 影音先锋一区| 日韩视频在线你懂得| 亚洲在线免费| 久久这里有精品视频| 欧美日韩国产精品专区| 国产区在线观看成人精品| 亚洲国产成人av在线| 亚洲图片欧美日产| 久久久久久婷| 欧美日韩在线视频观看| 国内精品模特av私拍在线观看| 亚洲精品一区二区三区蜜桃久| 午夜国产一区| 欧美成人免费在线观看| 国产麻豆视频精品| 91久久国产自产拍夜夜嗨| 亚洲伊人网站| 久久国产免费看| 欧美日韩播放| 韩国av一区二区三区| 99视频在线精品国自产拍免费观看 | 亚洲一级一区| 久久婷婷国产综合国色天香| 欧美日韩成人网| 国产亚洲欧洲997久久综合| 亚洲毛片在线看| 久久成人精品电影| 欧美日韩中国免费专区在线看| 国产一级一区二区| 99国产精品| 久久亚洲欧美| 国产精品美女久久久| 最新国产成人在线观看| 欧美一区二区三区啪啪| 欧美日韩国产小视频| 尤物网精品视频| 午夜精品久久久久| 欧美多人爱爱视频网站| 国内精品一区二区| 亚洲综合激情| 欧美精品久久久久a| 国内久久视频| 亚洲欧美综合v| 欧美日韩精品伦理作品在线免费观看| 激情一区二区三区| 午夜激情综合网| 欧美日本在线一区| 亚洲电影免费观看高清完整版在线| 午夜视频一区在线观看| 欧美日韩一区二区三区免费| 亚洲第一偷拍| 久久黄色级2电影| 国产精品美女久久久久av超清| 亚洲精品婷婷| 久久综合色一综合色88| 国产精品永久| 亚洲一区在线播放| 国产精品夫妻自拍| av不卡在线看| 欧美国产日韩一区| 亚洲国产91| 久久夜色精品国产| 国产在线成人| 欧美一级艳片视频免费观看| 国产精品久久毛片a| 一区二区三区精品国产| 欧美片第1页综合| 亚洲理论在线观看| 欧美电影免费观看网站| 亚洲日本激情| 欧美二区不卡| 亚洲精品国产无天堂网2021| 欧美电影免费观看大全| 最新亚洲激情| 欧美华人在线视频| 亚洲美女视频| 欧美日韩国产欧| 99国产精品国产精品毛片| 欧美激情在线有限公司| 亚洲精品一区二区三区婷婷月| 欧美精品亚洲二区| 99ri日韩精品视频| 欧美视频网址| 亚洲综合日本| 国产免费成人在线视频| 久久国产精品高清| 激情成人综合| 免费成人小视频| 亚洲肉体裸体xxxx137| 欧美久久在线| 一本久道久久久| 欧美性久久久| 午夜精品剧场| 国内精品久久久久久久影视蜜臀 | 中日韩美女免费视频网站在线观看| 欧美日韩色综合| 亚洲一级网站| 国产精品尤物福利片在线观看| 欧美一区二区三区在线播放| 国内自拍视频一区二区三区| 另类欧美日韩国产在线| 亚洲日本乱码在线观看| 欧美日韩视频在线| 亚洲一区二区精品| 国产欧美视频在线观看| 久久精品综合| 91久久精品国产91久久性色tv| 欧美伦理91i| 亚洲免费综合| 国外成人网址| 欧美激情亚洲另类| 亚洲亚洲精品三区日韩精品在线视频 | 中文精品视频一区二区在线观看| 国产精品女人网站| 六月婷婷一区| 一区二区三区 在线观看视| 国产精品亚洲成人| 久久亚洲春色中文字幕| 亚洲九九爱视频| 国产精品人人做人人爽人人添| 久久精品免费| 亚洲精品在线电影| 国产老女人精品毛片久久| 久久视频在线免费观看| 一本色道久久综合亚洲精品不| 国产欧美日韩精品专区| 欧美不卡视频一区发布| 一区二区三区蜜桃网| 国内精品国语自产拍在线观看| 欧美区一区二| 欧美一区二区三区喷汁尤物| 91久久精品日日躁夜夜躁国产| 国产精品美女久久久久久免费| 久久久噜噜噜久噜久久| 一本一本a久久| 狠狠色狠色综合曰曰| 欧美日韩在线一区二区| 久久久久久综合| 中文网丁香综合网| 亚洲丶国产丶欧美一区二区三区| 国产精品videosex极品| 久久亚洲国产精品一区二区| 亚洲午夜三级在线| 亚洲国产精品第一区二区| 国产精品视频大全| 欧美伦理a级免费电影| 久久久99精品免费观看不卡| 一区二区三区四区五区精品视频| 原创国产精品91| 国产精品视频导航| 欧美精品一区在线观看| 久久精品国产亚洲一区二区| 一区二区三区福利| 亚洲高清免费在线| 国产日韩精品久久| 欧美日韩一区免费| 噜噜噜91成人网| 欧美尤物一区| 亚洲一区欧美激情| 99成人精品| 亚洲激情视频在线| 激情欧美亚洲| 国产日韩精品一区二区浪潮av |