国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

javascript性能優(yōu)化之事件委托實例詳解

2024-05-06 16:26:10
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了javascript性能優(yōu)化之事件委托用法,結合實例形式對比分析了JavaScript中事件委托的具體用法與優(yōu)點,需要的朋友可以參考下
 

本文實例分析了javascript性能優(yōu)化之事件委托。分享給大家供大家參考,具體如下:

為下面每個LI綁定一個click事件

<ul id="myLinks">  <li id="goSomewhere" >Go somewhere</li>  <li id="doSomething" >Do something</li>  <li id="sayHi" >Say hi</li></ul>

一、傳統寫法

var item1=document.getElementById("goSomewhere");var item2=document.getElementById("doSomething");var item3=document.getElementById("sayHi");item1.onclick = function(){  console.log('goSomewhere');}item2.onclick = function(){  console.log('doSomething');}item3.onclick = function(){  alert("hello");}

在javascript中,添加到頁面上的事件處理程序數量將直接關系到頁面的整體運行性能,事件越多,性能越差。

導致原因是多方面:

1、每個函數都是對象,都會占用內存;內存中的對象越多,性能就越差。
2、必須事先指定所有事件處理程序而導致的DOM訪問次數,會延遲整個頁面的交互就緒時間。

二、事件委托

對“事件處理程序過多”問題的解決方案就是事件委托。

事件委托利用了事件冒泡,只指定一個事件處理程序,就可以管理某一類型的所有事件。例如:click事件會一直冒泡到document層次。也就是說,我們可以為整個頁面指定一個onclick事件處理程序,而不必給每個可單擊的元素分別添加事件處理程序。

事件委托方法:

var list=document.getElementById("myLinks");list.onclick = function(e){  var target = e.target;    switch(target.id){   case "goSomewhere":    console.log('goSomewhere');    break;    case "doSomething":    console.log('doSomething');    break;    case "sayHi":    alert("hello");    break;   }}

三、使用事件委托的優(yōu)點:

1)document對象很快就可以訪問,而且可以在頁面生命周期的任何時間點上為它添加事件處理程序(無需等待DOMContentLoaded或load事件)。換句話說,只要可單擊的元素呈現在頁面上,就可以立即具備適當的功能。

2)在頁面中設置事件處理程序所需的時間更少。只添加一個事件處理程序所需的Dom引用更少,所花的時間也更少。

3)整個頁面占用的內存空間更少,能夠提升整體性能。

希望本文所述對大家JavaScript程序設計有所幫助。



注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 屏南县| 旌德县| 双柏县| 饶河县| 韶山市| 开原市| 华宁县| 襄汾县| 赤壁市| 清原| 天津市| 嘉兴市| 石棉县| 邛崃市| 汉源县| 肇源县| 涟源市| 七台河市| 金门县| 任丘市| 晋江市| 乐昌市| 盐源县| 霍林郭勒市| 阳城县| 五华县| 察雅县| 米脂县| 奉化市| 秦皇岛市| 中超| 家居| 怀集县| 大连市| 宜兰市| 宁陕县| 扎赉特旗| 密山市| 鱼台县| 修文县| 慈利县|