js事件機(jī)制:冒泡與捕獲

基礎(chǔ)知識(shí)

1.操作系統(tǒng)最先知道用戶點(diǎn)擊了鼠標(biāo)救拉,瀏覽器次之
2.child 被點(diǎn)擊了娶聘,意味著 parent 也被點(diǎn)擊了
3.如果我同時(shí)監(jiān)聽(tīng)了 child 和 parent蹦误,那么誰(shuí)先通知我扔仓?這是個(gè)問(wèn)題芜赌。

捕獲階段

parent 先通知其爵,child 后通知

<body>
  <div class="parent">
    <div class="child"></div>
  </div>
<script>
  var parent = document.getElementsByClassName("parent")[0];
  var child = document.getElementsByClassName("child")[0];
  child.addEventListener('click',function(){
    console.log("child")
  },true)
  parent.addEventListener('click',function(){
    console.log("parent");
  },true)
  document.body.addEventListener('click',function(){
    console.log("body");
  },true)
</script>
</body>

當(dāng)點(diǎn)擊chlid時(shí)冒冬,控制臺(tái)依次顯示如下:

捕獲從window開(kāi)始,到document,再到html,再到body摩渺,再到被點(diǎn)擊元素的祖先元素简烤,再到被點(diǎn)擊元素的父元素,最后到被點(diǎn)擊的元素摇幻。一級(jí)一級(jí)往下找横侦,只要有監(jiān)聽(tīng)事件,就執(zhí)行绰姻。用一幅圖描述枉侧,如下:

Capture Phase就是捕獲階段,只有早期 Navigator 默認(rèn)支持它狂芋,所以我們一般不用「捕獲階段」榨馁。Bubbling Phase是冒泡階段,一般用「冒泡階段」帜矾。

冒泡階段

child 先通知翼虫,parent 后通知
IE 一開(kāi)始就支持冒泡。

<body>
  <div class="parent">
    <div class="child"></div>
  </div>
<script>
  var parent = document.getElementsByClassName("parent")[0];
  var child = document.getElementsByClassName("child")[0];
  child.addEventListener('click',function(){
    console.log("child")
  })
  parent.addEventListener('click',function(){
    console.log("parent");
  })
  document.body.addEventListener('click',function(){
    console.log("body");
  })
</script>
</body>

當(dāng)點(diǎn)擊chlid時(shí)屡萤,控制臺(tái)顯示如下:

冒泡跟捕獲相反珍剑,從被點(diǎn)擊的元素開(kāi)始,到被點(diǎn)擊元素的父元素死陆,再到被點(diǎn)擊元素的祖先元素招拙,再到body,再到html措译,再到document迫像,最后到window,一級(jí)一級(jí)往上冒瞳遍,有監(jiān)聽(tīng)事件就執(zhí)行。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末菌羽,一起剝皮案震驚了整個(gè)濱河市掠械,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖猾蒂,帶你破解...
    沈念sama閱讀 211,817評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件均唉,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡肚菠,警方通過(guò)查閱死者的電腦和手機(jī)舔箭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,329評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)蚊逢,“玉大人层扶,你說(shuō)我怎么就攤上這事±雍桑” “怎么了镜会?”我有些...
    開(kāi)封第一講書人閱讀 157,354評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)终抽。 經(jīng)常有香客問(wèn)我戳表,道長(zhǎng),這世上最難降的妖魔是什么昼伴? 我笑而不...
    開(kāi)封第一講書人閱讀 56,498評(píng)論 1 284
  • 正文 為了忘掉前任匾旭,我火速辦了婚禮,結(jié)果婚禮上圃郊,老公的妹妹穿的比我還像新娘价涝。我一直安慰自己,他們只是感情好描沟,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,600評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布飒泻。 她就那樣靜靜地躺著,像睡著了一般吏廉。 火紅的嫁衣襯著肌膚如雪泞遗。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 49,829評(píng)論 1 290
  • 那天席覆,我揣著相機(jī)與錄音史辙,去河邊找鬼。 笑死佩伤,一個(gè)胖子當(dāng)著我的面吹牛聊倔,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播生巡,決...
    沈念sama閱讀 38,979評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼耙蔑,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了孤荣?” 一聲冷哼從身側(cè)響起甸陌,我...
    開(kāi)封第一講書人閱讀 37,722評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤须揣,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后钱豁,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體耻卡,經(jīng)...
    沈念sama閱讀 44,189評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,519評(píng)論 2 327
  • 正文 我和宋清朗相戀三年牲尺,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了卵酪。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,654評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡谤碳,死狀恐怖溃卡,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情估蹄,我是刑警寧澤塑煎,帶...
    沈念sama閱讀 34,329評(píng)論 4 330
  • 正文 年R本政府宣布,位于F島的核電站臭蚁,受9級(jí)特大地震影響最铁,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜垮兑,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,940評(píng)論 3 313
  • 文/蒙蒙 一冷尉、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧系枪,春花似錦雀哨、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,762評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至衬浑,卻和暖如春捌浩,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背工秩。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,993評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工尸饺, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人助币。 一個(gè)月前我還...
    沈念sama閱讀 46,382評(píng)論 2 360
  • 正文 我出身青樓浪听,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親眉菱。 傳聞我的和親對(duì)象是個(gè)殘疾皇子迹栓,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,543評(píng)論 2 349

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

  • 學(xué)這個(gè)的時(shí)候迈螟,這東西把我搞得很頭暈叉抡。于是決定寫一篇Blog出來(lái)把這玩意說(shuō)清楚,讓和我一樣在這個(gè)坑里打滾的人不那么暈...
    CoderMageFox閱讀 631評(píng)論 0 3
  • 背景知識(shí) 什么是事件答毫?直觀的說(shuō)就是網(wǎng)頁(yè)上發(fā)生的事情,大部分是指用戶的鼠標(biāo)動(dòng)作和鍵盤動(dòng)作季春,如點(diǎn)擊洗搂、移動(dòng)鼠標(biāo)、按下某個(gè)...
    吧啦啦小湯圓閱讀 1,838評(píng)論 2 15
  • 0.起因 前幾天寫業(yè)務(wù)的時(shí)候,碰到了這樣的需求: checkbox在父DIV的里面,但是checkbox綁定了v-...
    CoderMageFox閱讀 913評(píng)論 1 0
  • JavaScript與HTML之間的交互是通過(guò)事件來(lái)實(shí)現(xiàn)的载弄,事件就是當(dāng)文檔或者瀏覽器窗口發(fā)生一些特定的交互瞬間耘拇,事...
    plainnany閱讀 963評(píng)論 1 2
  • 孩兒倒是挺努力的,也挺上心宇攻,有時(shí)候我都佩服他惫叛,背書寫作業(yè)都對(duì)自己要求完美,就是剛開(kāi)學(xué)的時(shí)候聽(tīng)老師說(shuō)逞刷,他上課的時(shí)候嘉涌,...
    詹詹zmz閱讀 188評(píng)論 0 0