事件委托

還有很多要學,要加油哇〖碓螅回正題慎菲。
參考: js中的事件委托或是事件代理詳解

1、基本概念
事件委托就是利用事件冒泡聂抢,只指定一個事件處理程序钧嘶,就可以管理某一類型的所有事件棠众。
使用事件委托技術(shù)能避免對特定的每個節(jié)點添加事件監(jiān)聽器琳疏,事件監(jiān)聽器是被添加到它們的父元素上。事件監(jiān)聽器會分析從子元素冒泡上來的事件闸拿,找到是哪個子元素的事件空盼。可用于操作動態(tài)添加的節(jié)點新荤。

2揽趾、為什么要用事件委托
一般來說,dom需要有事件處理程序苛骨,我們都會直接給它設(shè)事件處理程序就好了篱瞎,那如果是很多的dom需要添加事件處理呢?比如我們有100個li痒芝,每個li都有相同的click點擊事件俐筋,可能我們會用for循環(huán)的方法,來遍歷所有的li严衬,然后給它們添加事件澄者,那這么做會存在什么影響呢?
在JavaScript中请琳,添加到頁面上的事件處理程序數(shù)量將直接關(guān)系到頁面的整體運行性能粱挡,因為需要不斷的與dom節(jié)點進行交互,訪問dom的次數(shù)越多俄精,引起瀏覽器重繪與重排的次數(shù)也就越多询筏,就會延長整個頁面的交互就緒時間,這就是為什么性能優(yōu)化的主要思想之一就是減少DOM操作的原因竖慧;如果要用事件委托嫌套,就會將所有的操作放到j(luò)s程序里面,與dom的操作就只需要交互一次测蘑,這樣就能大大的減少與dom的交互次數(shù)灌危,提高性能
每個函數(shù)都是一個對象碳胳,是對象就會占用內(nèi)存勇蝙,對象越多,內(nèi)存占用率就越大挨约,自然性能就越差了(占內(nèi)存)味混,比如上面的100個li产雹,就要占用100個內(nèi)存空間。如果用事件委托翁锡,那么我們就可以只對它的父級(如果只有一個父級)這一個對象進行操作蔓挖,這樣我們就需要一個內(nèi)存空間就夠了,自然性能就會更好馆衔。

3瘟判、例子
HTML代碼:

 <ul id="parent-list">
    <li id="post-1">Item 1</li>
    <li id="post-2">Item 2</li>
    <li id="post-3">Item 3</li>
    <li id="post-4">Item 4</li>
    <li id="post-5">Item 5</li>
    <li id="post-6">Item 6</li>
</ul>

JS代碼:
當子元素的事件冒泡到父ul元素時,你可以檢查事件對象的target屬性角溃,捕獲真正被點擊的節(jié)點元素的引用拷获。下面是一段很簡單的JavaScript代碼,演示了事件委托的過程:

// 找到父元素减细,添加監(jiān)聽器...
document.getElementById("parent-list").addEventListener("click",function(e) {
    // e.target是被點擊的元素!
    // 如果被點擊的是li元素
    if(e.target && e.target.nodeName == "LI") {
        // 找到目標匆瓜,輸出ID!
        console.log("List item ",e.target.id.replace("post-")," was clicked!");
    }
});

第一步是給父元素添加事件監(jiān)聽器。當有事件觸發(fā)監(jiān)聽器時未蝌,檢查事件的來源驮吱,排除非li子元素事件。如果是一個li元素萧吠,即目標左冬!如果不是一個li元素,事件將被忽略怎憋。

4又碌、適用場景
適合用事件委托的事件:click,mousedown绊袋,mouseup毕匀,keydown,keyup癌别,keypress皂岔。
值得注意的是,mouseover和mouseout雖然也有事件冒泡展姐,但是處理它們的時候需要特別的注意躁垛,因為需要經(jīng)常計算它們的位置,處理起來不太容易圾笨。
不適合的就有很多了教馆,舉個例子,mousemove擂达,每次都要計算它的位置土铺,非常不好把控,在不如說focus,blur之類的悲敷,本身就沒用冒泡的特性究恤,自然就不能用事件委托了。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末后德,一起剝皮案震驚了整個濱河市部宿,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌瓢湃,老刑警劉巖理张,帶你破解...
    沈念sama閱讀 216,843評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異箱季,居然都是意外死亡涯穷,警方通過查閱死者的電腦和手機棍掐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,538評論 3 392
  • 文/潘曉璐 我一進店門藏雏,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人作煌,你說我怎么就攤上這事掘殴。” “怎么了粟誓?”我有些...
    開封第一講書人閱讀 163,187評論 0 353
  • 文/不壞的土叔 我叫張陵奏寨,是天一觀的道長。 經(jīng)常有香客問我鹰服,道長病瞳,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,264評論 1 292
  • 正文 為了忘掉前任悲酷,我火速辦了婚禮套菜,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘设易。我一直安慰自己逗柴,他們只是感情好,可當我...
    茶點故事閱讀 67,289評論 6 390
  • 文/花漫 我一把揭開白布顿肺。 她就那樣靜靜地躺著戏溺,像睡著了一般。 火紅的嫁衣襯著肌膚如雪屠尊。 梳的紋絲不亂的頭發(fā)上般堆,一...
    開封第一講書人閱讀 51,231評論 1 299
  • 那天啊央,我揣著相機與錄音,去河邊找鬼。 笑死晰搀,一個胖子當著我的面吹牛会前,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 40,116評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼止潘,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了辫诅?” 一聲冷哼從身側(cè)響起凭戴,我...
    開封第一講書人閱讀 38,945評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎炕矮,沒想到半個月后么夫,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,367評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡肤视,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,581評論 2 333
  • 正文 我和宋清朗相戀三年档痪,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片邢滑。...
    茶點故事閱讀 39,754評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡腐螟,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出困后,到底是詐尸還是另有隱情乐纸,我是刑警寧澤,帶...
    沈念sama閱讀 35,458評論 5 344
  • 正文 年R本政府宣布摇予,位于F島的核電站汽绢,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏侧戴。R本人自食惡果不足惜宁昭,卻給世界環(huán)境...
    茶點故事閱讀 41,068評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望酗宋。 院中可真熱鬧积仗,春花似錦、人聲如沸本缠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,692評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽丹锹。三九已至稀颁,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間楣黍,已是汗流浹背匾灶。 一陣腳步聲響...
    開封第一講書人閱讀 32,842評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留租漂,地道東北人阶女。 一個月前我還...
    沈念sama閱讀 47,797評論 2 369
  • 正文 我出身青樓颊糜,卻偏偏與公主長得像,于是被迫代替她去往敵國和親秃踩。 傳聞我的和親對象是個殘疾皇子衬鱼,可洞房花燭夜當晚...
    茶點故事閱讀 44,654評論 2 354

推薦閱讀更多精彩內(nèi)容