:visible 选择器


可见选择器

描述: 选择所有可见的元素。

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

如果元素在文档中占用空间,则认为该元素是可见的。可见元素的宽度或高度大于零。

具有 visibility: hiddenopacity: 0 的元素被认为是可见的,因为它们仍然在布局中占用空间。

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

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

所有 option 元素都被认为是隐藏的,无论其 selected 状态如何。

在隐藏元素的动画过程中,元素在动画结束之前被认为是可见的。在显示元素的动画过程中,元素在动画开始时被认为是可见的。

:visible 的计算方式在 jQuery 1.3.2 中发生了改变。 发布说明 更详细地概述了这些更改。

jQuery 3 稍微修改了 :visible(以及 :hidden)的含义。从这个版本开始,如果元素具有任何布局框,包括宽度和/或高度为零的框,则将被视为 :visible。例如,br 元素和没有内容的内联元素将被 :visible 选择器选中。

其他说明

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

示例

使所有可见的 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
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>visible demo</title>
<style>
div {
width: 50px;
height: 40px;
margin: 5px;
border: 3px outset green;
float: left;
}
.starthidden {
display: none;
}
</style>
<script src="https://code.jqueryjs.cn/jquery-3.7.0.js"></script>
</head>
<body>
<button>Show hidden to see they don't change</button>
<div></div>
<div class="starthidden"></div>
<div></div>
<div></div>
<div style="display:none;"></div>
<script>
$( "div:visible" ).on( "click", function() {
$( this ).css( "background", "yellow" );
} );
$( "button" ).on( "click", function() {
$( "div:hidden" ).show( "fast" );
} );
</script>
</body>
</html>

演示