• <abbr id="chdyf"></abbr>
    <ruby id="chdyf"><acronym id="chdyf"><meter id="chdyf"></meter></acronym></ruby>
    <bdo id="chdyf"></bdo>
    <dfn id="chdyf"><menu id="chdyf"></menu></dfn>
    1. <menuitem id="chdyf"></menuitem><strong id="chdyf"><menu id="chdyf"></menu></strong>

      <rt id="chdyf"><menu id="chdyf"></menu></rt>
      成人小说一区二区三区,伊人精品成人久久综合全集观看,久久HEZYO色综合,中文字幕精品人妻熟女,影音先锋成人网站,我要看免费一级毛片,中国女人做爰A片,中文字幕av久久爽Av

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

       

      日歷

      鏈接

      個人資料

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

      存檔

      主站蜘蛛池模板: 在线观看片免费人成视频无码| 亚洲资源在线| 亚洲专区熟女| 日本免费有码中文字幕| 91手机在线视频| 免费看无码网站成人A片| 粉嫩av一区二区在线观看| 欧美一z黄片一区2区| 在线观看国产精品一区自拍| 亚洲福利天堂网福利在线观看| 国产小精品| 亚洲三区自拍| 人妻少妇偷人无码视频| 伊人精品成人久久综合欧美| 国产麻豆剧传媒精品国产AV| 富婆熟妇熟女二区三区| 人妻少妇精品| 丁香婷婷六月| 在线永久免费观看黄网站| 国产女同疯狂摩擦奶6| 草草地址线路①屁屁影院成人| 亚洲AV噜噜狠狠网址蜜桃| 惠水县| 超碰人人草| 超碰人人干| 3PAV乱伦视频| 国产午夜精品美女免费大片| 日韩免费视频一一二区| 六月丁香婷婷色狠狠久久| 伊人查蕉在线观看国产精品| 欧美日韩亚洲视频| 色色二区| 五月丁香六月激情| 伊人宗合| 亚洲中文字幕免费| 无码AV网站| 国产破处视频| 中文字幕亚洲在线| 有码人妻动慢| 国产精品免费久久久久软件| 中字无码av在线电影|