js利用事件的阻止冒泡實現(xiàn)點擊空白模態(tài)框的隱藏
更新時間:2014年01月24日 15:00:33 作者:
點擊彈出某個框框,但是,有時候不想操作,就想點擊某個空白處,隱藏該框框,關(guān)于這一點,下面有個具體的實現(xiàn)
很多時候,我們做前端的時候都會有這樣的小功能,點擊彈出某個框框,但是,有時候不想操作,就想點擊某個空白處,隱藏該框框。假設(shè)如下場景,一個小按鈕,點擊可以彈出一個模態(tài)框。
就這么簡單,但是我們想要點擊空白部分的時候隱藏模態(tài)框,加入按鈕id:btn,模態(tài)框id:model
也許我們最簡單的思路就是直接在document上監(jiān)聽一個事件,偽代碼如下:
按鈕點擊彈出事件監(jiān)聽:
$("#btn").bind("click",function(e){
if(e.stopPropagation){//需要阻止冒泡
e.stopPropagation();
}else{
e.cancelBubble = true;
}
})
$(document).bind("click",function(e){
if(點擊事件不在model上){
隱藏模態(tài)框;
}
})
乍一看,這是沒有問題的,但是,其實有很多問題,首先,我們得注意阻止冒泡,否則,點擊按鈕,實際是觸發(fā)了上面兩個事件,modal是彈不出來的,其實是彈出來了,立馬又隱藏了,而且,當我們在模態(tài)框上還有許多小控件的時候,我們對于模態(tài)框中的點擊就很難進行判斷。
這里,我認為有一種最經(jīng)典的方法,很簡單,但是很巧妙,
首先,對于模態(tài)框監(jiān)聽一個事件如下:
$("#modal").bind("click", function(event) {
if (event && event.stopPropagation) {
event.stopPropagation();
} else {
event.cancelBubble = true;
}
});
只是簡單阻止模態(tài)框中的點擊事件冒泡,
然后:
$(document).one("click", function(e){
var $target = $(e.currentTarget);
if ($target.attr("id") != "modal") {
$("#modal").css("display", "none");
}
});
搞定,so easy
就這么簡單,但是我們想要點擊空白部分的時候隱藏模態(tài)框,加入按鈕id:btn,模態(tài)框id:model
也許我們最簡單的思路就是直接在document上監(jiān)聽一個事件,偽代碼如下:
按鈕點擊彈出事件監(jiān)聽:
復制代碼 代碼如下:
$("#btn").bind("click",function(e){
if(e.stopPropagation){//需要阻止冒泡
e.stopPropagation();
}else{
e.cancelBubble = true;
}
})
復制代碼 代碼如下:
$(document).bind("click",function(e){
if(點擊事件不在model上){
隱藏模態(tài)框;
}
})
乍一看,這是沒有問題的,但是,其實有很多問題,首先,我們得注意阻止冒泡,否則,點擊按鈕,實際是觸發(fā)了上面兩個事件,modal是彈不出來的,其實是彈出來了,立馬又隱藏了,而且,當我們在模態(tài)框上還有許多小控件的時候,我們對于模態(tài)框中的點擊就很難進行判斷。
這里,我認為有一種最經(jīng)典的方法,很簡單,但是很巧妙,
首先,對于模態(tài)框監(jiān)聽一個事件如下:
復制代碼 代碼如下:
$("#modal").bind("click", function(event) {
if (event && event.stopPropagation) {
event.stopPropagation();
} else {
event.cancelBubble = true;
}
});
只是簡單阻止模態(tài)框中的點擊事件冒泡,
然后:
復制代碼 代碼如下:
$(document).one("click", function(e){
var $target = $(e.currentTarget);
if ($target.attr("id") != "modal") {
$("#modal").css("display", "none");
}
});
搞定,so easy
您可能感興趣的文章:
- AngularJs 彈出模態(tài)框(model)
- JS實現(xiàn)圖片點擊后出現(xiàn)模態(tài)框效果
- js實現(xiàn)簡單模態(tài)框?qū)嵗?/a>
- Vue.js彈出模態(tài)框組件開發(fā)的示例代碼
- angularJS模態(tài)框$modal實例代碼
- AngularJS中使用ngModal模態(tài)框?qū)嵗?/a>
- bootstrap Validator 模態(tài)框、jsp、表單驗證 Ajax提交功能
- AngularJS模態(tài)框模板ngDialog的使用詳解
- 原生js實現(xiàn)簡單的模態(tài)框示例
- JavaScript+CSS實現(xiàn)模態(tài)框效果
相關(guān)文章
BootStrap Table復選框默認選中功能的實現(xiàn)代碼(從數(shù)據(jù)庫獲取到對應(yīng)的狀態(tài)進行判斷是否為選中狀態(tài))
本文通過實例代碼給大家介紹了BootStrap Table復選框默認選中功能(從數(shù)據(jù)庫獲取到對應(yīng)的狀態(tài)進行判斷是否為選中狀態(tài)),代碼簡單易懂,非常不錯,具有參考借鑒價值,需要的的朋友參考下吧2017-07-07js中如何復制一個對象并獲取其所有屬性和屬性對應(yīng)的值
如果知道這個對象的所有屬性自然就可以重新new一個,然后對每個屬性賦值,就可以做到,但如果不知道呢?如何創(chuàng)建一個內(nèi)容相同 的對象呢?下面有個不錯的示例,大家可以看看2013-10-10Highcharts 多個Y軸動態(tài)刷新數(shù)據(jù)的實現(xiàn)代碼
下面小編就為大家?guī)硪黄狧ighcharts 多個Y軸動態(tài)刷新數(shù)據(jù)的實現(xiàn)代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-05-05ES6使用 Array.includes 處理多重條件用法實例分析
這篇文章主要介紹了ES6使用 Array.includes 處理多重條件用法,結(jié)合實例形式分析了Array.includes基本功能、原理及處理多重條件相關(guān)操作技巧,需要的朋友可以參考下2020-03-03