zoukankan      html  css  js  c++  java
  • 点击页面其它地方将某个显示的DIV隐藏


    此文中有一个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=" 200px">
            <div class="language_selected">
                中文(简体)</div>
            <div class="language_list">
                <ul>
                    <li>中文(简体)</li>
                    <li>English</li>
                </ul>
            </div>
        </div>
        <div id="noPopEvent" style=" 100px; height: 100px; border: 1px solid black;">
            点击我,不隐藏语言列表,需要自己显示DIV
        </div>
  • 相关阅读:
    LOGO生成器
    【转】 iOS开发:Debug与Release版本NSLog屏蔽方法
    【转】IOS调试技巧:当程序崩溃的时候怎么办 iphone IOS
    【转】 Objective C实现多继承
    NSArray
    记一次 ios程序 内存优化记录LOG日志
    【转】[iOS] 关于 self = [super init];
    NSMutableArray
    Xcode调试利器 Instruments用户指南
    一段代码展现一个流程,流程在代码中内聚
  • 原文地址:https://www.cnblogs.com/dataadapter/p/2588156.html
Copyright © 2011-2022 走看看