概述 visible selector
返回值:Array<Element(s)>
描述:选择所有可见的元素。
如果元素中占据文档中一定的空间,元素被认为是可见的。可见元素的宽度或高度,是大于零。
元素的visibility: hidden
或 opacity: 0
被认为是可见的,因为他们仍然占用空间布局。
不在文档中的元素是被认为隐藏的;jQuery没有办法知道他们是否是可见的,因为元素可见性依赖于适用的样式。
此选择器正好与:hidden
选择器相反。
因此,通过:visible
选择的每一个元素,不能通过:hidden
选择匹配,反之亦然。
所有 option
元素是被认为是隐藏的, 不管他们是否selected
(选中)状态.
隐藏元素上做动画,元素被认为是可见的,直到动画结束。显示元素上做动画,在动画的开始处该元素被认为是可见的。
:visible
的计算方法是在jQuery 1.3.2改变。 发行说明中列出更详细的变化。
jQuery 3稍微修改了:visible
(以及:hidden
)的含义。
这个版本开始,如果一个元素只要有任何布局盒,即使宽度和/或高度为0,那么它将被视为:visible
。例如,br
元素和没有内容的内联元素将都能通过:visible
选择器被选择。
:visible
是一个 jQuery 延伸出来的选择器,并不是的CSS规范的一部分,使用:visible
查询不能充分利用原生DOM提供的querySelectorAll()
方法来提高性能。为了当使用:visible
的时候在现代浏览器上获得更佳的性能,首先使用纯CSS选择器选择元素,然后使用.filter(":visible")
代替.
示例
查找所有可见的 tr 元素
<table>
<tr style="display:none"><td>Value 1</td></tr>
<tr><td>Value 2</td></tr>
</table>
$("tr:visible")
[ <tr><td>Value 2</td></tr> ]
在所有可见的 div 上添加事件,当点击后变成黄色。
- <!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.jquery.com/jquery-1.10.2.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" ).click(function() {
- $( this ).css( "background", "yellow" );
- });
- $( "button" ).click(function() {
- $( "div:hidden" ).show( "fast" );
- });
- </script>
- </body>
- </html>