事件委托

利用?JS 事件冒泡動(dòng)態(tài)為元素綁定事件的方法稱為事件委托(Event Delegation飒责,也稱為“事件代理”),是 JavaScript 中最熱門的技術(shù)之一仿便。

事件委托就是把原本需要綁定在子元素上的事件(onclick靶累、onkeydown 等)委托給它的父元素顾患,讓父元素來監(jiān)聽子元素的冒泡事件暇检,并在子元素發(fā)生事件冒泡時(shí)找到這個(gè)子元素款熬。

舉個(gè)簡(jiǎn)單的例子深寥,整個(gè)宿舍的同學(xué)都需要去取快遞,一種方法是讓他們一個(gè)個(gè)去取贤牛,另一種方法是把這件事委托給宿舍長(zhǎng)惋鹅,讓宿舍長(zhǎng)把所有人的快遞都取回來,然后再根據(jù)收件人一一分發(fā)給宿舍的同學(xué)殉簸。在這里闰集,我們可以將取快遞看作一個(gè)事件;每個(gè)同學(xué)看作是需要綁定事件的 DOM 元素般卑;宿舍長(zhǎng)看作是這些 DOM 元素的父元素武鲁,事件需要綁定在這個(gè)父元素上;按照收件人分發(fā)快遞的過程就是事件執(zhí)行的過程椭微。

為什么要使用事件委托

在 JavaScript 中洞坑,頁面內(nèi)事件處理程序的個(gè)數(shù)會(huì)直接影響頁面的整體性能,因?yàn)槊總€(gè)事件處理程序都是對(duì)象蝇率,對(duì)象會(huì)占用內(nèi)存迟杂,內(nèi)存中的對(duì)象越多,頁面的性能則越差本慕。此外排拷,事件處理程序需要與 DOM 節(jié)點(diǎn)進(jìn)行交互,訪問 DOM 的次數(shù)越多锅尘,引起瀏覽器重繪和重排的次數(shù)也就越多监氢,從而影響頁面的性能布蔗。

重繪是指當(dāng)元素樣式改變時(shí),瀏覽器會(huì)根據(jù)元素的新樣式重新繪制元素的外觀浪腐。重排是指當(dāng) DOM 樹的一部分發(fā)生變化時(shí)(例如元素尺寸改變)纵揍,瀏覽器會(huì)重新創(chuàng)建 DOM 樹。

當(dāng)頁面中很多表格或列表需要添加事件時(shí)议街,如果逐個(gè)添加那就太麻煩了泽谨,但是使用事件委托就能極大的減輕我們的工作量,同時(shí)也能提高頁面的性能特漩。

事件委托實(shí)現(xiàn)原理

事件委托是利用事件的冒泡原理來實(shí)現(xiàn)的吧雹,大致可以分為三個(gè)步驟:

1.確定要添加事件元素的父級(jí)元素;

2.給父元素定義事件涂身,監(jiān)聽子元素的冒泡事件雄卷;

3.使用 event.target 來定位觸發(fā)事件冒泡的子元素。

注意:使用事件委托時(shí)蛤售,并不是說把事件委托給隨意一個(gè)父元素就行丁鹉。因?yàn)槭录芭莸倪^程也需要消耗時(shí)間,距離越遠(yuǎn)悴能,所需的時(shí)間也就越長(zhǎng)鳄炉,所有最好在直接父元素上使用事件委托。


通過上面的代碼可以看出搜骡,要為每個(gè) li 標(biāo)簽綁定點(diǎn)擊事件拂盯,首先需要找到 ul 標(biāo)簽,然后通過 ul 標(biāo)簽找到所有 li 標(biāo)簽记靡, 最后在通過遍歷所有 li 標(biāo)簽來綁定事件谈竿。若使用事件委托的話,就會(huì)簡(jiǎn)單很多摸吠,示例代碼如下:


通過代碼可以看出空凸,使用事件委托我們只需要為 ul 標(biāo)簽綁定事件,當(dāng) li 標(biāo)簽被點(diǎn)擊時(shí)寸痢,由于事件冒泡的特性呀洲,會(huì)觸發(fā) ul 標(biāo)簽上的事件,我們只需要在事件中通過 event 對(duì)象中的 target 屬性來找到被點(diǎn)擊的 li 標(biāo)簽即可啼止。不過這樣做也有一個(gè)弊端道逗,那就是當(dāng)我們點(diǎn)擊 ul 標(biāo)簽時(shí),也會(huì)觸發(fā)事件献烦。

另外滓窍,如果我們需要?jiǎng)討B(tài)的向 ul 標(biāo)簽中添加 li 標(biāo)簽,同時(shí)也需要在新添加的 li 標(biāo)簽中添加點(diǎn)擊事件巩那,就必須通過事件委托來實(shí)現(xiàn)了吏夯,示例代碼如下:


?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末此蜈,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子噪生,更是在濱河造成了極大的恐慌裆赵,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,290評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件跺嗽,死亡現(xiàn)場(chǎng)離奇詭異顾瞪,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)抛蚁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來惕橙,“玉大人瞧甩,你說我怎么就攤上這事∶逐校” “怎么了肚逸?”我有些...
    開封第一講書人閱讀 156,872評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)彬坏。 經(jīng)常有香客問我朦促,道長(zhǎng),這世上最難降的妖魔是什么栓始? 我笑而不...
    開封第一講書人閱讀 56,415評(píng)論 1 283
  • 正文 為了忘掉前任务冕,我火速辦了婚禮,結(jié)果婚禮上幻赚,老公的妹妹穿的比我還像新娘禀忆。我一直安慰自己,他們只是感情好落恼,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,453評(píng)論 6 385
  • 文/花漫 我一把揭開白布箩退。 她就那樣靜靜地躺著,像睡著了一般佳谦。 火紅的嫁衣襯著肌膚如雪戴涝。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,784評(píng)論 1 290
  • 那天钻蔑,我揣著相機(jī)與錄音啥刻,去河邊找鬼。 笑死咪笑,一個(gè)胖子當(dāng)著我的面吹牛郑什,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蒲肋,決...
    沈念sama閱讀 38,927評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼蘑拯,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼钝满!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起申窘,我...
    開封第一講書人閱讀 37,691評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤弯蚜,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后剃法,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體碎捺,經(jīng)...
    沈念sama閱讀 44,137評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,472評(píng)論 2 326
  • 正文 我和宋清朗相戀三年贷洲,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了收厨。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,622評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡优构,死狀恐怖诵叁,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情钦椭,我是刑警寧澤拧额,帶...
    沈念sama閱讀 34,289評(píng)論 4 329
  • 正文 年R本政府宣布,位于F島的核電站彪腔,受9級(jí)特大地震影響侥锦,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜德挣,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,887評(píng)論 3 312
  • 文/蒙蒙 一恭垦、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧格嗅,春花似錦署照、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至懂扼,卻和暖如春禁荸,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背阀湿。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來泰國(guó)打工赶熟, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人陷嘴。 一個(gè)月前我還...
    沈念sama閱讀 46,316評(píng)論 2 360
  • 正文 我出身青樓映砖,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親灾挨。 傳聞我的和親對(duì)象是個(gè)殘疾皇子邑退,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,490評(píng)論 2 348

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