點擊頁面其它地方將某個顯示的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="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>

 

 

 

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM