6.阻止事件冒泡

來看一個簡單的下拉框例子

<!--html代碼-->
<body>
    <input type="text">
    <ul style="display:none;">    <!--為了節(jié)省空間這里采用了行內(nèi)樣式-->
        <li>下拉列表1</li>
        <li>下拉列表2</li>
        <li>下拉列表3</li>
        <li>下拉列表4</li>
        <li>下拉列表5</li>
    </ul>
</body>

分為如下幾個步驟:

  1. 首先需要獲取到三個元素
var input = document.querySelector('input');
var ul = document.querySelector('ul');
var lis = document.querySelectorAll('li');
  1. 一個下拉框在點(diǎn)擊的時候,下拉列表需要顯示
input.onclick=function(){
      ul.style.display='block';
};
  1. 當(dāng)點(diǎn)擊下拉列表里面的內(nèi)容時浦译,下拉框會消失,點(diǎn)擊的內(nèi)容會顯示在下拉框內(nèi)
for(var i=0;i<lis.length;i++){
      lis[i].onclick=function(){
          input.value=this.innerHTML;
          ul.style.display='none';
      };
};

以上步驟均正常運(yùn)行溯职,然后到了下一步

  1. 點(diǎn)擊頁面時精盅,下拉列表也會消失
document.onclick=fucntion(){
      ul.style.display='none';
};

此時,由于在點(diǎn)擊了input后谜酒,在事件冒泡的過程中叹俏,遇到了document的點(diǎn)擊事件,并觸發(fā)了它的事件處理函數(shù)僻族,那么在頁面上的表現(xiàn)結(jié)果就是下拉框無法顯示了粘驰,這里我們就需要在點(diǎn)擊input的時候阻止事件冒泡

input.onclick=function(ev){
      ul.style.display='block';
      ev.cancelBubble=true;
};

這么個功能就做好了

如果碰到事件冒泡時觸發(fā)了其他事件處理函數(shù),這時候只需要在觸發(fā)事件的目標(biāo)元素身上加上阻止事件冒泡的代碼述么,就可以輕松的解決這個問題了
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蝌数,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子度秘,更是在濱河造成了極大的恐慌顶伞,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,627評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異唆貌,居然都是意外死亡滑潘,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評論 3 399
  • 文/潘曉璐 我一進(jìn)店門锨咙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來语卤,“玉大人,你說我怎么就攤上這事蓖租×宦拢” “怎么了?”我有些...
    開封第一講書人閱讀 169,346評論 0 362
  • 文/不壞的土叔 我叫張陵蓖宦,是天一觀的道長齐婴。 經(jīng)常有香客問我,道長稠茂,這世上最難降的妖魔是什么柠偶? 我笑而不...
    開封第一講書人閱讀 60,097評論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮睬关,結(jié)果婚禮上诱担,老公的妹妹穿的比我還像新娘。我一直安慰自己电爹,他們只是感情好蔫仙,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,100評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著丐箩,像睡著了一般摇邦。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上屎勘,一...
    開封第一講書人閱讀 52,696評論 1 312
  • 那天施籍,我揣著相機(jī)與錄音,去河邊找鬼概漱。 笑死丑慎,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的瓤摧。 我是一名探鬼主播竿裂,決...
    沈念sama閱讀 41,165評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼姻灶!你這毒婦竟也來了铛绰?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,108評論 0 277
  • 序言:老撾萬榮一對情侶失蹤产喉,失蹤者是張志新(化名)和其女友劉穎捂掰,沒想到半個月后敢会,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,646評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡这嚣,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,709評論 3 342
  • 正文 我和宋清朗相戀三年鸥昏,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片姐帚。...
    茶點(diǎn)故事閱讀 40,861評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡吏垮,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出罐旗,到底是詐尸還是另有隱情膳汪,我是刑警寧澤,帶...
    沈念sama閱讀 36,527評論 5 351
  • 正文 年R本政府宣布九秀,位于F島的核電站遗嗽,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏鼓蜒。R本人自食惡果不足惜痹换,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,196評論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望都弹。 院中可真熱鬧娇豫,春花似錦、人聲如沸畅厢。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,698評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽框杜。三九已至系羞,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間霸琴,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,804評論 1 274
  • 我被黑心中介騙來泰國打工昭伸, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留梧乘,地道東北人。 一個月前我還...
    沈念sama閱讀 49,287評論 3 379
  • 正文 我出身青樓庐杨,卻偏偏與公主長得像选调,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子灵份,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,860評論 2 361

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