国产黄色免费网站_久久天天做天天爱综合色_精品国产一区久久久_成人黄色激情网站_久久成人在线视频_美女一区二区在线观看_亚洲精品免费一区亚洲精品免费精品一区 _91精品国产综合久久精品麻豆

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

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

 

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

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

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

事件委托

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

補(bǔ)充一下:事件委托并不局限于父節(jié)點與子節(jié)點之間。也可以這樣玩,比如頁面文檔中有好多個處在不同位置地 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),都會彈出一個框,來顯示我們點擊了哪個子列表。

需求不難吧?有了需求,接下來是該寫 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);

看著上面的代碼,我這里寫幾點方法二的優(yōu)點: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);

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

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

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

移除事件處理程序

我們前面說過,事件處理程序存在于內(nèi)存中,每當(dāng)將事件處理程序指定給元素時,運行中的瀏覽器代碼與支持頁面交互的 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.newchinaweekly.com )是一家專注而深入的界面設(shè)計公司,為期望卓越的國內(nèi)外企業(yè)提供卓越的UI界面設(shè)計BS界面設(shè)計 、 cs界面設(shè)計 、 ipad界面設(shè)計 、 包裝設(shè)計 、 圖標(biāo)定制 、 用戶體驗 、交互設(shè)計、 網(wǎng)站建設(shè) 平面設(shè)計服務(wù) 

 

日歷

鏈接

個人資料

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

存檔

久久天天躁夜夜躁狠狠躁2022| 国产亚洲一区二区三区不卡| 国产精品美女久久久久| 99久久婷婷国产综合精品| 欧美高清视频在线播放| 亚洲手机在线观看| 欧美先锋影音| 欧美亚洲一区二区三区四区| 中国特级黄色片| 国产乱视频在线观看| 亚洲成a人v欧美综合天堂下载| 波多野结衣久草一区| 在线免费观看高清视频| 欧美影视一区| 欧美在线视频网站| 国产免费电影网站入口| 自拍视频一区| 99精品在线直播| 东北一级毛片| 国产激情精品久久久第一区二区| 亚洲三级免费看| 国产永久免费视频| 老司机成人在线| 日韩一区av在线| 欧美色视频一区二区三区在线观看| 久久99国产精品久久99大师| 国产日韩中文字幕在线| 成年人视频免费| 欧美午夜精品| 国产日韩欧美精品| 999精品国产| heyzo一本久久综合| 99999精品视频| 国产无遮挡裸体视频在线观看| 欧美一区二区二区| 亚洲自拍偷拍另类| 亚洲一区图片| 97在线观看视频| 狠狠干五月天| 不卡一区二区在线| 欧美日韩中文在线视频| 免费av不卡在线观看| 欧美一区二区三区婷婷月色 | 日韩网站在线| 大地资源第二页在线观看高清版| 亚洲国产精品无码久久| 国产精品美女久久久久高潮| 亚洲精品第二页| 免费一区二区三区四区| 成人免费视频观看视频| 岛国在线视频网站| 精品国产一区二区三区免费| 福利一区二区免费视频| 日本视频一区在线观看| 亚洲一区网址| 成人午夜电影在线播放| 天天躁日日躁狠狠躁超碰2020| 亚洲成人精品视频| av一级毛片| 亚洲国产三级网| 中文 欧美 日韩| wwwwxxxxx欧美| 亚洲精品字幕在线| 亚洲成a人v欧美综合天堂下载| 亚洲欧美综合一区二区| 久久久久久电影| 久久婷婷国产麻豆91| 亚洲视频香蕉人妖| 中文字幕av网站| 日韩欧美精品在线观看| 免费尤物视频| 夜色激情一区二区| 性欧美videos精品| 亚洲午夜激情av| 青青草视频导航| 中文字幕日本欧美| 日日日日影院| 国产视频亚洲视频| 国产超级va在线视频| 欧美怡春院一区二区三区| 在线观看wwww| 欧美激情欧美激情| 四虎在线精品| 亚洲一级免费在线观看| 成人精品gif动图一区| 丰满人妻一区二区三区四区| 一区二区三区影院| 天堂在线亚洲| 成人午夜小视频| 成人线上视频| 欧美性猛xxx| 亚洲高潮女人毛茸茸| 很黄很黄激情成人| 男人日女人网站| 欧美综合第一页| 欧美中文日韩| 免费av福利| 成人在线看视频| 欧洲国内综合视频| 性插视频在线观看| 精品视频免费在线| 国产精品一区二区入口九绯色| 日本久久一二三四| 少妇真人直播免费视频| 欧美一区二区在线免费观看| 国产福利片在线观看| 永久免费看黄网站| 欧美洲成人男女午夜视频| 天堂一区二区在线| 中文字幕一区二区三区四区视频| 国产69精品久久久久9999| 精品中文在线| 国产av无码专区亚洲a∨毛片| 国产伦精品一区二区三区| 性欧美69xoxoxoxo| 91久久精品| 看看黄色一级片| 亚洲色无码播放| 亚洲国产二区| 天堂在线第六区| avav在线播放| 久久综合一区二区| 久草在线视频福利| 中文字幕日韩三级| 日韩欧美视频第二区| 国产真实乱偷精品视频免| 在线资源免费观看| 91av在线免费播放| 日韩av在线免费观看| 99精品热6080yy久久| 日本欧美亚洲| 精品视频一区二区在线观看| 99精品在线直播| 欧美日韩一区二区三区免费看| 亚洲区小说区图片区qvod按摩| 影音先锋中文在线观看| 国产福利精品av综合导导航| 欧美三级特黄| 一级毛片电影| 女同性恋一区二区三区| 午夜精品久久久久久久99热浪潮| 91丨porny丨在线| 亚洲福利影视| 狠狠色噜噜狠狠狠8888米奇| wwwwww日本| 久久视频国产精品免费视频在线| 亚洲成人tv| 日本一区视频| 亚洲女同二女同志奶水| 欧美人与性动交a欧美精品| 久久久久国产精品厨房| 国产精品欧美大片| 久草网站在线| 无码无遮挡又大又爽又黄的视频| 韩剧1988在线观看免费完整版| 亚洲美女视频在线| ririsao久久精品一区| 国产一级中文字幕| 欧美午夜性视频| 国产99久久精品一区二区永久免费 | aaaa黄色片| 亚洲精品一区中文字幕乱码| 成人动漫一区二区| 精品国产午夜| 免费a级在线播放| 日日爱66.cn| 91久久国语露脸精品国产高跟| 美女日批在线观看| 综合网中文字幕| 黑人巨大精品欧美一区二区一视频| 电影一区二区三区| 黄色大秀av大片| 日本久久天堂| 久草视频在线观| 岛国精品一区二区三区| 日本黄xxxxxxxxx100| 亚洲欧美日韩一区二区三区在线| 日韩黄色片在线观看| av黄色在线观看| 国产三级小视频| 久久久久人妻一区精品色| 91视频免费版污| 欧美一区二区三区在线免费观看 | 九九精品久久| 久草免费在线视频| 深夜影院在线观看| 成人在色线视频在线观看免费大全 | 在线免费日韩| 女同互忝互慰dv毛片观看| 国产极品一区二区三区| av老司机久久| 国产在线观看第一页| av黄色在线播放| 欧美精品入口蜜桃| 国风产精品一区二区| 欧美极品色图| 久久久av免费| 欧美成在线观看| 在线观看免费亚洲| 亚洲第一主播视频|