點擊空白區域關閉彈出框

點擊區域外的空白處隱藏彈出框

最近在做一個搜索框,點擊圖標可以顯示出搜索框,再次點擊可以顯示選中后的結果,但是點擊區域外的空白處也是可以收縮彈出框
大致的樣子就是這樣


navbar.png
shownavbar.png

在網上搜索的到以下的解決方案

  //點擊空白區域隱藏彈出框(全局)
            $(document).click(function(e){

                // 目標區域,點擊某個彈出的區域
              var pop = $('#search-navbar');

                if(!pop.is(e.target) && pop.has(e.target).length === 0) {
                    //點擊外圍區域隱藏彈出框
                    self.isOpen = false;
                    $scope.$evalAsync();
                }else{
                    //點擊目標區域不隱藏
                    self.isOpen = true;
                    $scope.$evalAsync();
                }
            });

w3c上這樣解釋is方法

is() 根據選擇器、元素或 jQuery 對象來檢測匹配元素集合,如果這些元素中至少有一個元素匹配給定的參數,則返回 true。

if ( $target.is("li,span") ) {
    $target.css("background-color", "red");
  }

這段就是表示點擊的要素要么包括li,要么包括span,否則背景不變成紅色

w3c上這樣解釋has方法

has() 將匹配元素集合縮減為擁有匹配指定選擇器或 DOM 元素的后代的子集。
如果給定一個表示 DOM 元素集合的 jQuery 對象,.has() 方法用匹配元素的子集來構造一個新的 jQuery 對象。所使用的選擇器用于檢測匹配元素的后代;如果任何后代元素匹配該選擇器,該元素將被包含在結果中。

$('li').has('ul').css('background-color', 'red');

這段只是表示,只有選定的li元素下有ul ,ul是li的后代元素才會使背景色變成紅色;

這段代碼也相對較好吧,可以試著使用。

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • (續jQuery基礎(1)) 第5章 DOM節點的復制與替換 (1)DOM拷貝clone() 克隆節點是DOM的常...
    凜0_0閱讀 1,364評論 0 8
  • 第一章 入門 基本功能:訪問和操作 dom 元素,控制頁面樣式,對頁面的事件處理,與ajax完美結合,有豐富的插件...
    X_Arts閱讀 1,066評論 0 2
  • $(”p”).addClass(css中定義的樣式類型); 給某個元素添加樣式 $(”img”).attr({sr...
    專注寒冰三千歲閱讀 513評論 0 4
  • Attribute: $("p").addClass(css中定義的樣式類型); 給某個元素添加樣式 $("img...
    撲克臉_457e閱讀 591評論 0 1
  • 原文鏈接 http://blog.poetries.top/2016/10/20/review-jQuery 關注...
    前端進階之旅閱讀 16,679評論 18 503