隐藏选择器
描述: 选择所有隐藏的元素。
版本添加: 1.0jQuery( ":hidden" )
元素可能由于以下几个原因被视为隐藏
- 它们具有 CSS
display
值为none
。 - 它们是具有
type="hidden"
的表单元素。 - 它们的宽度和高度显式设置为 0。
- 它们的祖先元素被隐藏,因此该元素在页面上不可见。
具有 visibility: hidden
或 opacity: 0
的元素被认为是可见的,因为它们在布局中仍然占用空间。在隐藏元素的动画过程中,元素在动画结束之前被认为是可见的。
不在文档中的元素不被认为是可见的;jQuery 无法知道它们在附加到文档时是否可见,因为这取决于适用的样式。
此选择器与 :visible
选择器相反。因此,每个被 :hidden
选择的元素都不会被 :visible
选择,反之亦然。
在显示元素的动画过程中,元素在动画开始时被认为是可见的。
在 jQuery 1.3.2 中,:hidden
的确定方式发生了改变。如果元素本身或其任何父元素在文档中不占用空间,则该元素被认为是隐藏的。CSS 可见性不会被考虑在内(因此 $( elem ).css( "visibility", "hidden" ).is( ":hidden" ) == false
)。发布说明 更详细地概述了这些更改。
jQuery 3 稍微修改了 :hidden
(以及 :visible
)的含义。从这个版本开始,如果元素没有布局框,则会被视为 :hidden
。例如,br
元素和没有内容的内联元素将不会被 :hidden
选择器选中。
其他说明
-
因为
:hidden
是 jQuery 的扩展,而不是 CSS 规范的一部分,所以使用:hidden
的查询无法利用原生 DOMquerySelectorAll()
方法提供的性能提升。为了在使用: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
|
|