CSS: fix :visible/:hidden selectors for inline element w/ content

- Reverts behavior from 10399dd, which we never released.
  BR and inline elements are considered visible.
- The possibility of dropping .offsetWidth and .offsetHeight
  was debunked by this perf:
  http://jsperf.com/visible-hidden-and-getclientrects

Fixes gh-2227
Close gh-2281
This commit is contained in:
Timmy Willison
2015-05-08 15:27:54 -07:00
parent fe2a584ed6
commit dd816dbac1
2 changed files with 17 additions and 13 deletions

View File

@@ -6,15 +6,13 @@ define([
], function( jQuery, support ) {
jQuery.expr.filters.hidden = function( elem ) {
// Use OR instead of AND as the element is not visible if either is true
// See tickets #10406 and #13132
return !elem.offsetWidth || !elem.offsetHeight ||
(!support.reliableHiddenOffsets() &&
((elem.style && elem.style.display) || jQuery.css( elem, "display" )) === "none");
return !jQuery.expr.filters.visible( elem );
};
jQuery.expr.filters.visible = function( elem ) {
return !jQuery.expr.filters.hidden( elem );
return !!( elem.offsetWidth || elem.offsetHeight || elem.getClientRects().length ) &&
( support.reliableHiddenOffsets() ||
( ( elem.style && elem.style.display ) || jQuery.css( elem, "display" ) ) !== "none" );
};
});