代码改变世界

点击页面其它地方将某个显示的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>