当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


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。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。