加载中...

:visible


概述    visible selector

返回值:Array<Element(s)>

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

  • V : 1.0jQuery( ":visible" )

如果元素中占据文档中一定的空间,元素被认为是可见的。可见元素的宽度或高度,是大于零。

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

不在文档中的元素是被认为隐藏的;jQuery没有办法知道他们是否是可见的,因为元素可见性依赖于适用的样式。

此选择器正好与:hidden选择器相反。 因此,通过:visible选择的每一个元素,不能通过:hidden选择匹配,反之亦然。

所有 option 元素是被认为是隐藏的, 不管他们是否selected(选中)状态.

隐藏元素上做动画,元素被认为是可见的,直到动画结束。显示元素上做动画,在动画的开始处该元素被认为是可见的。

:visible的计算方法是在jQuery 1.3.2改变。 发行说明中列出更详细的变化。

jQuery 3稍微修改了:visible (以及:hidden)的含义。 这个版本开始,如果一个元素只要有任何布局盒,即使宽度和/或高度为0,那么它将被视为:visible。例如,br 元素和没有内容的内联元素将都能通过:visible选择器被选择。

Additional Notes(其他注意事项):

  • 因为:visible 是一个 jQuery 延伸出来的选择器,并不是的CSS规范的一部分,使用:visible 查询不能充分利用原生DOM提供的querySelectorAll()方法来提高性能。为了当使用:visible 的时候在现代浏览器上获得更佳的性能,首先使用纯CSS选择器选择元素,然后使用.filter(":visible")代替.
  • 使用这个选择器很大程度上可能具有性能问题,因为它可能会迫使浏览器重新渲染页面才能够确定他的可见性。通过其他方法跟踪元素的可见性,例如使用的一样式类,能够提供更好的性能。

示例

实例

查找所有可见的 tr 元素

HTML 代码:
  1. <table>
  2. <tr style="display:none"><td>Value 1</td></tr>
  3. <tr><td>Value 2</td></tr>
  4. </table>
jQuery 代码:
  1. $("tr:visible")
结果:
  1. [ <tr><td>Value 2</td></tr> ]

实例

在所有可见的 div 上添加事件,当点击后变成黄色。

  1. <!doctype html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8">
  5. <title>visible demo</title>
  6. <style>
  7. div {
  8. width: 50px;
  9. height: 40px;
  10. margin: 5px;
  11. border: 3px outset green;
  12. float: left;
  13. }
  14. .starthidden {
  15. display: none;
  16. }
  17. </style>
  18. <script src="https://code.jquery.com/jquery-1.10.2.js"></script>
  19. </head>
  20. <body>
  21. <button>Show hidden to see they don't change</button>
  22. <div></div>
  23. <div class="starthidden"></div>
  24. <div></div>
  25. <div></div>
  26. <div style="display:none;"></div>
  27. <script>
  28. $( "div:visible" ).click(function() {
  29. $( this ).css( "background", "yellow" );
  30. });
  31. $( "button" ).click(function() {
  32. $( "div:hidden" ).show( "fast" );
  33. });
  34. </script>
  35. </body>
  36. </html>

运行一下


还没有评论.