當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


JQuery :hidden用法及代碼示例


用法
hidden selector

說明:選擇所有隱藏的元素。

  • 添加的版本:1.0jQuery( ":hidden" )

元素可以被認為是隱藏的,原因如下:

  • 它們的 CSS display 值為 none
  • 它們是帶有 type="hidden" 的表單元素。
  • 它們的寬度和高度明確設置為 0。
  • 祖先元素是隱藏的,因此該元素不會顯示在頁麵上。

帶有visibility: hiddenopacity: 0 的元素被認為是可見的,因為它們仍然占用布局中的空間。在隱藏元素的動畫期間,該元素被認為是可見的,直到動畫結束。

不在文檔中的元素被認為是不可見的; jQuery 沒有辦法知道它們在附加到文檔時是否可見,因為它取決於適用的樣式。

此選擇器與 :visible 選擇器相反。因此,:hidden 選擇的每個元素都不會被:visible 選擇,反之亦然。

在顯示元素的動畫期間,該元素被認為在動畫開始時可見。

:hidden 的確定方式在 jQuery 1.3.2 中有所改變。如果一個元素或其任何父元素在文檔中沒有占用空間,則假定它是隱藏的。不考慮 CSS 可見性(因此 $( elem ).css( "visibility", "hidden" ).is( ":hidden" ) == false )。 release notes 更詳細地概述了更改。

jQuery 3 略微修改了 :hidden 的含義(因此也修改了 :visible 的含義)。從這個版本開始,如果元素沒有任何布局框,則將被視為:hidden。例如,br 元素和沒有內容的內聯元素將不會被 :hidden 選擇器選中。

其他注意事項:

  • 因為 :hidden 是 jQuery 擴展而不是 CSS 規範的一部分,所以使用 :hidden 的查詢無法利用本機 DOM querySelectorAll() 方法提供的性能提升。為了在使用 :hidden 選擇元素時獲得最佳性能,首先使用純 CSS 選擇器選擇元素,然後使用 .filter(":hidden")
  • 大量使用此選擇器可能會對性能產生影響,因為它可能會強製瀏覽器在確定可見性之前重新渲染頁麵。通過其他方法(例如使用類)跟蹤元素的可見性可以提供更好的性能。

例子:

顯示所有隱藏的 div 並計算隱藏的輸入。

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>hidden demo</title>
  <style>
  div {
    width: 70px;
    height: 40px;
    background: #e7f;
    margin: 5px;
    float: left;
  }
  span {
    display: block;
    clear: left;
    color: red;
  }
  .starthidden {
    display: none;
  }
  </style>
  <script src="https://code.jquery.com/jquery-3.5.0.js"></script>
</head>
<body>
 
<span></span>
<div></div>
<div style="display:none;">Hider!</div>
<div></div>
 
<div class="starthidden">Hider!</div>
<div></div>
 
<form>
  <input type="hidden">
  <input type="hidden">
  <input type="hidden">
</form>
 
<span></span>
 
<script>
// In some browsers :hidden includes head, title, script, etc...
var hiddenElements = $( "body" ).find( ":hidden" ).not( "script" );
 
$( "span" ).first().text( "Found " + hiddenElements.length + " hidden elements total." );
$( "div:hidden" ).show( 3000 );
$( "span" ).last().text( "Found " + $( "input:hidden" ).length + " hidden inputs." );
</script>
 
</body>
</html>

演示:

相關用法


注:本文由純淨天空篩選整理自jquery.com大神的英文原創作品 :hidden。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。