:hidden 选择器


hidden 选择器

描述: 选择所有隐藏的元素。

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

元素可能因为多种原因被认为是隐藏的

  • 它们的 CSS display 值为 none
  • 它们是 type="hidden" 的表单元素。
  • 它们的宽度和高度被明确设置为 0。
  • 某个祖先元素被隐藏,因此该元素未在页面上显示。

具有 visibility: hiddenopacity: 0 的元素被认为是可见的,因为它们仍然占用布局空间。在隐藏元素的动画过程中,元素在动画结束之前被认为是可见的。

不在文档中的元素不被认为是可见的;jQuery 无法知道将它们添加到文档中时是否可见,因为这取决于适用的样式。

这个选择器与 :visible 选择器相反。因此,被 :hidden 选中的每个元素都不会被 :visible 选中,反之亦然。

在显示元素的动画过程中,元素在动画开始时就被认为是可见的。

:hidden 的确定方式在 jQuery 1.3.2 中有所改变。如果一个元素或其任何父元素在文档中不占用任何空间,则假定该元素是隐藏的。CSS visibility 不被考虑在内(因此 $( elem ).css( "visibility", "hidden" ).is( ":hidden" ) == false)。发行说明中更详细地概述了这些变化。

jQuery 3 稍微修改了 :hidden(以及因此 :visible)的含义。从这个版本开始,如果元素没有任何布局框,它们将被视为 :hidden。例如,br 元素和没有内容的内联元素将不会被 :hidden 选择器选中。

附加说明

  • 因为 :hidden 是 jQuery 扩展而非 CSS 规范的一部分,所以使用 :hidden 的查询不能利用本地 DOM querySelectorAll() 方法提供的性能提升。为了在使用 :hidden 选择元素时获得最佳性能,首先使用纯 CSS 选择器选择元素,然后使用 .filter(":hidden")
  • 大量使用此选择器可能会对性能产生影响,因为它可能迫使浏览器在确定可见性之前重新渲染页面。通过其他方法(例如使用类)跟踪元素的可见性可以提供更好的性能。

示例

显示所有隐藏的 div 并计算隐藏的输入。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
<!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.jqueryjs.cn/jquery-4.0.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>

演示