中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

JavaScript事件對內存和性能的影響有哪些

這篇文章給大家分享的是有關JavaScript 事件對內存和性能的影響有哪些的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

為岫巖等地區(qū)用戶提供了全套網(wǎng)頁設計制作服務,及岫巖網(wǎng)站建設行業(yè)解決方案。主營業(yè)務為網(wǎng)站設計制作、成都做網(wǎng)站、岫巖網(wǎng)站設計,以傳統(tǒng)方式定制建設網(wǎng)站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!

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

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

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

事件委托

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

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

下面舉例子逐步說明事件委托的優(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>

假設有上面的代碼,我們現(xiàn)在有一個需求:就是無論單擊上面的列表(ul)的哪個子列表(li),都會彈出一個框,來顯示我們點擊了哪個子列表。

需求不難吧?有了需求,接下來是該寫 js 代碼了,現(xiàn)在有兩種方法放在你眼前:1. 為每個 li 子元素綁定 click 事件,然后設置處理函數(shù); 2. 利用事件委托,為 ul 父元素綁定 click 事件,然后設置處理函數(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)一綁定到其父元素,減少了對內存的占用;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 代碼之間就會建立一個連接。這種連接越多,頁面執(zhí)行就越慢。前面所說的事件委托就是用來限制建立的連接數(shù)量。

還有,就是內存中那些使用完后不再使用的事件處理程序,如果不釋放掉,也會影響 Web 應用程序的內存和性能。

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

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

感謝各位的閱讀!關于“JavaScript 事件對內存和性能的影響有哪些”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

網(wǎng)站題目:JavaScript事件對內存和性能的影響有哪些
網(wǎng)站地址:http://www.rwnh.cn/article26/jispcg.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供做網(wǎng)站、品牌網(wǎng)站制作、營銷型網(wǎng)站建設建站公司、軟件開發(fā)、網(wǎng)站改版

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

外貿網(wǎng)站建設
琼中| 芦山县| 灵丘县| 平乡县| 视频| 林西县| 铁力市| 高安市| 农安县| 上犹县| 彰武县| 镇平县| 佳木斯市| 许昌市| 大同县| 玛纳斯县| 龙山县| 名山县| 卓尼县| 延津县| 乌恰县| 连平县| 定陶县| 平原县| 伊宁市| 萨迦县| 无为县| 澄江县| 蒙城县| 台州市| 舞阳县| 台南市| 双峰县| 芷江| 大邑县| 衡阳市| 台安县| 蓬溪县| 特克斯县| 湟中县| 盐山县|