aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRichard Gibson <richard.gibson@gmail.com>2017-07-31 12:36:54 -0400
committerGitHub <noreply@github.com>2017-07-31 12:36:54 -0400
commita49578499ec88c9fbca59ff0c80b23b798a55d99 (patch)
tree80d8ca0285711d25189fb1441254c062b56209f4
parent262acc6f1e0f71a3a8b786e3c421b2e645799ea0 (diff)
downloadjquery-a49578499ec88c9fbca59ff0c80b23b798a55d99.tar.gz
jquery-a49578499ec88c9fbca59ff0c80b23b798a55d99.zip
Dimensions: Improve offsetWidth/offsetHeight fallback
Fixes gh-3698 Fixes gh-3602 Closes gh-3738
-rw-r--r--src/css.js11
-rw-r--r--test/unit/dimensions.js19
2 files changed, 28 insertions, 2 deletions
diff --git a/src/css.js b/src/css.js
index 87bf2481d..2395f42b4 100644
--- a/src/css.js
+++ b/src/css.js
@@ -163,10 +163,17 @@ function getWidthOrHeight( elem, dimension, extra ) {
valueIsBorderBox = valueIsBorderBox &&
( support.boxSizingReliable() || val === elem.style[ dimension ] );
- // Fall back to offsetWidth/Height when value is "auto"
+ // Fall back to offsetWidth/offsetHeight when value is "auto"
// This happens for inline elements with no explicit setting (gh-3571)
- if ( val === "auto" ) {
+ // Support: Android <=4.1 - 4.3 only
+ // Also use offsetWidth/offsetHeight for misreported inline dimensions (gh-3602)
+ if ( val === "auto" ||
+ !parseFloat( val ) && jQuery.css( elem, "display", false, styles ) === "inline" ) {
+
val = elem[ "offset" + dimension[ 0 ].toUpperCase() + dimension.slice( 1 ) ];
+
+ // offsetWidth/offsetHeight provide border-box values
+ valueIsBorderBox = true;
}
// Normalize "" and auto
diff --git a/test/unit/dimensions.js b/test/unit/dimensions.js
index 13cd9662b..991a59113 100644
--- a/test/unit/dimensions.js
+++ b/test/unit/dimensions.js
@@ -544,6 +544,25 @@ QUnit.test( "width/height on an inline element with no explicitly-set dimensions
} );
} );
+QUnit.test( "width/height on a table row with phantom borders (gh-3698)", function( assert ) {
+ assert.expect( 4 );
+
+ jQuery( "<table id='gh3698' style='border-collapse: separate; border-spacing: 0;'><tbody>" +
+ "<tr style='margin: 0; border: 10px solid black; padding: 0'>" +
+ "<td style='margin: 0; border: 0; padding: 0; height: 42px; width: 42px;'></td>" +
+ "</tr>" +
+ "</tbody></table>" ).appendTo( "#qunit-fixture" );
+
+ var $elem = jQuery( "#gh3698 tr" );
+
+ jQuery.each( [ "Width", "Height" ], function( i, method ) {
+ assert.equal( $elem[ "outer" + method ](), 42,
+ "outer" + method + " should match content dimensions" );
+ assert.equal( $elem[ "outer" + method ]( true ), 42,
+ "outer" + method + "(true) should match content dimensions" );
+ } );
+} );
+
QUnit.test( "interaction with scrollbars (gh-3589)", function( assert ) {
assert.expect( 48 );