嫩草影院久久99_老司机午夜网站国内精品久久久久久久久_久久夜色精品国产_国产一级做a爰片久久毛片

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

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

 

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

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

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

事件委托

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

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

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

<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)在有一個(gè)需求:就是無論單擊上面的列表(ul)的哪個(gè)子列表(li),都會(huì)彈出一個(gè)框,來顯示我們點(diǎn)擊了哪個(gè)子列表。

需求不難吧?有了需求,接下來是該寫 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. 減少了訪問 DOM 的次數(shù),提升了性能;2. 將子元素的事件處理程序統(tǒng)一綁定到其父元素,減少了對(duì)內(nèi)存的占用;3. 可以更好地管理事件處理程序,比如移除對(duì)某個(gè)事件處理程序的引用

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

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

因?yàn)槭录幸蕾囀录芭輽C(jī)制,所以,并不是所有的事件都可以進(jìn)行事件委托。

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

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

移除事件處理程序

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

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

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

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

 

藍(lán)藍(lán)設(shè)計(jì)m.sdgs6788.com )是一家專注而深入的界面設(shè)計(jì)公司,為期望卓越的國(guó)內(nèi)外企業(yè)提供卓越的UI界面設(shè)計(jì)BS界面設(shè)計(jì) 、 cs界面設(shè)計(jì) 、 ipad界面設(shè)計(jì) 、 包裝設(shè)計(jì) 、 圖標(biāo)定制 、 用戶體驗(yàn) 、交互設(shè)計(jì)、 網(wǎng)站建設(shè) 平面設(shè)計(jì)服務(wù) 

 

日歷

鏈接

個(gè)人資料

存檔

嫩草影院久久99_老司机午夜网站国内精品久久久久久久久_久久夜色精品国产_国产一级做a爰片久久毛片
<em id="09ttv"></em>
    <sup id="09ttv"><pre id="09ttv"></pre></sup>
    <dd id="09ttv"></dd>

        • 老司机一区二区| 欧美日韩成人综合| 国产日韩欧美精品一区| 91久久精品国产91性色tv| 欧美va日韩va| 日韩五码在线| 一区二区三区产品免费精品久久75 | 久久综合五月| 影音先锋亚洲电影| 欧美国产日本韩| 中文国产成人精品| 久久午夜电影网| 亚洲少妇在线| 伊人男人综合视频网| 亚洲国产美女| 国产精品久久午夜| 欧美大秀在线观看| 久久久99精品免费观看不卡| 亚洲精品久久久蜜桃| 欧美一区二区三区免费看| 亚洲国产精品高清久久久| 国产精品久久婷婷六月丁香| 国产欧美一区二区精品仙草咪| 欧美成人在线影院| 国产精品久久久久毛片软件| 激情成人综合| 国产一区二区三区丝袜| 欧美色图首页| 欧美国产精品久久| 国产精品乱码一区二区三区| 在线观看视频免费一区二区三区| 一区二区三区黄色| 蜜臀91精品一区二区三区| 久久久久久午夜| 羞羞答答国产精品www一本| 亚洲午夜久久久久久久久电影院| 亚洲成色最大综合在线| 国产一区白浆| 夜夜嗨av一区二区三区| 日韩午夜在线电影| 亚洲精品一区二区三| 亚洲精品视频二区| 欧美在线中文字幕| 久久久综合网站| 在线一区欧美| 欧美成人性生活| 一区二区在线观看av| 亚洲欧美一区二区激情| 久久国产精品99国产| 亚洲欧洲日韩综合二区| 久久综合网hezyo| 国外成人在线视频| 亚洲国产欧美不卡在线观看| 欧美亚洲在线观看| 在线视频亚洲| 国产精品xnxxcom| 国产一区二区成人久久免费影院| 亚洲一区二区在线免费观看视频| 午夜日韩av| av不卡在线| 久久av一区二区三区| 久久黄色网页| 欧美精品九九| 国产精品无人区| 亚洲成人资源网| 老司机免费视频久久| 欧美一区综合| 国产在线精品成人一区二区三区| 亚洲国产精品黑人久久久| 久久在线91| 久久一二三四| 国产精品女主播| 性久久久久久久| 欧美一区二区免费| 欧美夫妇交换俱乐部在线观看| 亚洲国产视频一区二区| 91久久亚洲| 国产精品乱码久久久久久| 欧美一区成人| 久久精品免费观看| 亚洲精品日韩综合观看成人91| 亚洲人成在线播放网站岛国| 欧美日韩1234| 欧美一区高清| 玖玖玖免费嫩草在线影院一区| 亚洲人精品午夜| 久久免费高清| 欧美mv日韩mv国产网站| 亚洲一区二区在线免费观看视频| 性色av一区二区三区| 欧美视频日韩视频在线观看| 午夜精品视频在线观看| 久久精品噜噜噜成人av农村| 最新国产精品拍自在线播放| 一区二区三区视频观看| 欧美日本亚洲| 最新日韩在线| 亚洲视频免费看| 黄色av日韩| 一本久久青青| 1024成人| 亚洲你懂的在线视频| 欧美新色视频| 欧美阿v一级看视频| 欧美在线观看视频| 日韩视频免费大全中文字幕| 欧美www视频| 国产精品美女久久久久久久 | 一区二区三区日韩在线观看| 国产亚洲永久域名| 亚洲美女视频| 亚洲国产精品久久久久秋霞蜜臀| 一级日韩一区在线观看| 在线国产日韩| 欧美一区二区三区视频在线| 日韩午夜激情av| 久久精品亚洲国产奇米99| 亚洲尤物视频在线| 欧美激情国产日韩精品一区18| 久久久xxx| 久久久久久国产精品mv| 狠狠色综合网| 亚洲一区免费视频| 国产一区二区你懂的| 亚洲精品免费一二三区| 亚洲第一搞黄网站| 欧美在线视频一区二区| 亚洲欧美日韩在线不卡| 亚洲欧美文学| 国内偷自视频区视频综合| 亚洲少妇在线| 亚洲欧美成人一区二区三区| 欧美美女bbbb| 亚洲人成在线观看网站高清| 亚洲高清久久久| 久久综合网hezyo| 噜噜噜躁狠狠躁狠狠精品视频 | 韩国精品久久久999| 亚洲欧美日韩在线一区| 欧美一区二区高清| 国产精品综合| 欧美国产亚洲视频| 欧美激情精品久久久久久蜜臀 | 国产精品久久久久久久久久ktv| 亚洲午夜电影网| 欧美日韩国语| 亚洲精品久久久久久久久久久久| 亚洲欧洲一区二区天堂久久| 久久午夜羞羞影院免费观看| 欧美aa在线视频| 亚洲日本成人网| 欧美日本韩国| 亚洲伊人网站| 久久久噜噜噜久久| 亚洲激情国产精品| 欧美日韩亚洲系列| 另类激情亚洲| 亚洲精品久久久久| 欧美视频日韩视频| 欧美亚洲在线播放| 欧美国产第一页| 国产精品免费视频xxxx| 亚洲男人第一网站| 蜜臀91精品一区二区三区| 亚洲欧洲综合| 国产精品久久久久国产精品日日| 午夜欧美电影在线观看| 欧美粗暴jizz性欧美20| 亚洲网友自拍| 激情av一区| 欧美日在线观看| 久久大香伊蕉在人线观看热2| 欧美激情一区二区三区全黄| 一区二区三区国产盗摄| 国产婷婷色一区二区三区| 欧美高清hd18日本| 欧美亚洲在线播放| 亚洲看片网站| 亚洲精品社区| 国产美女精品视频| 欧美激情视频免费观看| 午夜视频一区二区| 亚洲国产成人久久综合一区| 国内伊人久久久久久网站视频| 久久先锋资源| 亚洲自拍偷拍福利| 亚洲国产一区二区三区a毛片| 亚洲电影在线免费观看| 欧美午夜不卡在线观看免费| 久久久精品国产免大香伊| 日韩午夜电影av| 欧美成人午夜激情在线| 亚洲欧美久久久久一区二区三区| 亚洲人成久久| 黄色在线成人| 国产亚洲免费的视频看| 国产精品a久久久久| 欧美激情第4页| 母乳一区在线观看| 久久久久国色av免费观看性色|