<strike id="g3zqm"></strike>

      <cite id="g3zqm"></cite>

        <tr id="g3zqm"><center id="g3zqm"></center></tr>
        <pre id="g3zqm"><sup id="g3zqm"></sup></pre>
        <li id="g3zqm"></li>
      1. 少妇高潮激情一区二区三,免费av深夜在线观看,亚洲狼人久久伊人久久伊,久久精品人人做人人爽电影蜜月,黄色特级片一区二区三区,欧美日韩在线亚洲二区综二,极品少妇无套内射视频,日本极品少妇videossexhd

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

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

         

        雖說事件處理程序可以為現(xiàn)代 Web 頁面添加很強(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)之間。也可以這樣玩,比如頁面文檔中有好多個(gè)處在不同位置地 button,都是綁定 click 事件,使用事件委托,我們可以把這些個(gè)事件統(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)在有一個(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)行中的瀏覽器代碼與支持頁面交互的 JavaScript 代碼之間就會(huì)建立一個(gè)連接。這種連接越多,頁面執(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ì)www.hengshangtqd.cn )是一家專注而深入的界面設(shè)計(jì)公司,為期望卓越的國內(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è)人資料

        存檔

        主站蜘蛛池模板: 久久伊人色| 26uuu精品一区二区三区四区| 在线 欧美 中文 亚洲 精品| 国产精品午夜福利视频| 亚洲高潮喷水中文字幕| 337p粉嫩大胆噜噜噜| 99久久机热/这里只有精品| 一区二区三区国产亚洲网站| 小12萝8禁用铅笔自慰喷水| 色偷偷天堂av狠狠狠在| 欧美综合精品久久久久成人影院| 欧美精品久久天天躁免费观看 | 台东市| 国产资源精品中文字幕| www.91av.com| 久久久久国产精品人妻| 国产成人午夜精品永久免费| 亚洲中文字幕观看| 成人女人看片免费视频放人| 麻花传媒剧电影| 国产精品乱码一区二区三| 中文字幕熟女人妻偷伦| 777精品二区| 国产精品无码久久久久免费AV| 亚洲国产成人午夜在线一区 | 成人一区专区在线观看| 三级三级三级A级全黄| 亚洲精品福利视频| 黄色综合网| 99久久国产综合精品女同| 九九综合va免费看| 成人亚洲av免费在线| 国产伦精品一区二区三区视频痴汉 | 国产av剧情亚洲精品| 久热久精久品这里在线观看 | 久久久久久夜| 免费看欧美全黄成人片| 精品国产大片中文字幕| 日本视频一区在线观看免费| 国产成人AV国语在线观看| 日本黄色一区二区|