点击页面其它地方将某个显示的DIV隐藏
2012-07-12 15:09 Mike.Jiang 阅读(4244) 评论(2) 编辑 收藏 举报
此文中有一个BUG,改进后点击页面其它地方将某个显示的DIV隐藏(改进)
背景:今天一朋友问我“点击一按钮弹出一个DIV,然后要求点击页面其它地方隐藏这个DIV”。
先看效果:
点击我
- 中文(简体)
- English
点击我,不隐藏语言列表,需要自己隐藏DIV
实现也很简单,但需要注意的是,在点击显示的事件中,需要做阻止事件冒泡的处理,否则就触发页面的点击事件了。但这样做也有一个缺点,即如果同一个页面中如果也有事件阻止冒泡,则不能隐藏DIV,所以在这样的事件中需要特殊处理下:自己调用隐藏下DIV(但正常来说这样的事件并不多);
JS:
View Code
$(document).ready(function() { //语言头部的点击事件,显示语言列表 $(".language_selected").click(function(e) { $(".language_list").toggle(); e.stopPropagation(); //阻止事件冒泡,否则事件会冒泡到下面的文档点击事件 }); //点击文档时,隐藏语言列表 $(document).click(function() { $(".language_list").hide(); }); //点击语言列表中的语言项时,更新选中项,并隐藏语言列表 $(".language_list li").click(function() { $(".language_selected").text($(this).text()); $(".language_list").hide(); }); $("#noPopEvent").click(function(e) { e.stopPropagation(); }); });
CSS:
View Code
.language_selected { cursor: pointer; } .language_list { border: 1px solid black; display: none; } .language_list li { cursor: pointer; border: 1px solid red; }
HTML:
View Code
<div style="width: 200px"> <div class="language_selected"> 中文(简体)</div> <div class="language_list"> <ul> <li>中文(简体)</li> <li>English</li> </ul> </div> </div> <div id="noPopEvent" style="width: 100px; height: 100px; border: 1px solid black;"> 点击我,不隐藏语言列表,需要自己显示DIV </div>