aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorTimmy Willison <4timmywil@gmail.com>2018-11-11 17:34:43 -0500
committerTimmy Willison <4timmywil@gmail.com>2018-11-27 14:28:59 -0500
commit315199c156c5b822a857ca236bda123f01a2da37 (patch)
tree5b2a9efd150e508671b860b43b040c61c2d010f2 /test
parent13d0be101f9441f32a2d8528f4de7667d0ffa44b (diff)
downloadjquery-315199c156c5b822a857ca236bda123f01a2da37.tar.gz
jquery-315199c156c5b822a857ca236bda123f01a2da37.zip
Dimensions: fall back to offsetWidth/Height for border-box in IE
- Use getClientRects() to explicitly detect hidden/disconnected elements Close gh-4223 Fixes gh-4102
Diffstat (limited to 'test')
-rw-r--r--test/data/testsuite.css4
-rw-r--r--test/unit/dimensions.js32
2 files changed, 31 insertions, 5 deletions
diff --git a/test/data/testsuite.css b/test/data/testsuite.css
index f6225df30..b975e44df 100644
--- a/test/data/testsuite.css
+++ b/test/data/testsuite.css
@@ -142,3 +142,7 @@ section { background:#f0f; display:block; }
padding: 0;
margin: 0;
}
+
+.border-box, .border-box * {
+ box-sizing: border-box;
+}
diff --git a/test/unit/dimensions.js b/test/unit/dimensions.js
index ea7793ff9..36b07f11e 100644
--- a/test/unit/dimensions.js
+++ b/test/unit/dimensions.js
@@ -659,7 +659,9 @@ QUnit.test( "interaction with scrollbars (gh-3589)", function( assert ) {
parent = jQuery( "<div/>" )
.css( { position: "absolute", width: "1000px", height: "1000px" } )
.appendTo( "#qunit-fixture" ),
- fraction = jQuery( "<div style='width:4.5px;'/>" ).appendTo( parent ).width() % 1,
+ fraction = jQuery.support.boxSizingReliable() ?
+ jQuery( "<div style='width:4.5px;'/>" ).appendTo( parent ).width() % 1 :
+ 0,
borderWidth = 1,
padding = 2,
size = 100 + fraction,
@@ -695,10 +697,8 @@ QUnit.test( "interaction with scrollbars (gh-3589)", function( assert ) {
borderBox[ 0 ].offsetWidth;
if ( borderBoxLoss > 0 ) {
- borderBox.css( {
- width: ( size + borderBoxLoss ) + "px",
- height: ( size + borderBoxLoss ) + "px"
- } );
+ borderBox[ 0 ].style.width = ( size + borderBoxLoss ) + "px";
+ borderBox[ 0 ].style.height = ( size + borderBoxLoss ) + "px";
}
for ( i = 0; i < 3; i++ ) {
@@ -750,4 +750,26 @@ QUnit.test( "interaction with scrollbars (gh-3589)", function( assert ) {
}
} );
+QUnit.test( "outerWidth/Height for table cells and textarea with border-box in IE 11 (gh-4102)", function( assert ) {
+ assert.expect( 5 );
+ var $table = jQuery( "<table class='border-box' style='border-collapse: separate' />" ).appendTo( "#qunit-fixture" ),
+ $thead = jQuery( "<thead />" ).appendTo( $table ),
+ $firstTh = jQuery( "<th style='width: 200px;padding: 5px' />" ),
+ $secondTh = jQuery( "<th style='width: 190px;padding: 5px' />" ),
+ $thirdTh = jQuery( "<th style='width: 180px;padding: 5px' />" ),
+ $td = jQuery( "<td style='height: 20px;padding: 5px;border: 1px solid'>text</td>" ),
+ $tbody = jQuery( "<tbody />" ).appendTo( $table ),
+ $textarea = jQuery( "<textarea style='height: 0;padding: 2px;border: 1px solid;box-sizing: border-box' />" ).appendTo( "#qunit-fixture" );
+ jQuery( "<tr />" ).appendTo( $thead ).append( $firstTh );
+ jQuery( "<tr />" ).appendTo( $thead ).append( $secondTh );
+ jQuery( "<tr />" ).appendTo( $thead ).append( $thirdTh );
+ jQuery( "<tr><td></td></tr>" ).appendTo( $tbody ).append( $td );
+
+ assert.strictEqual( $firstTh.outerWidth(), 200, "First th has outerWidth 200." );
+ assert.strictEqual( $secondTh.outerWidth(), 200, "Second th has outerWidth 200." );
+ assert.strictEqual( $thirdTh.outerWidth(), 200, "Third th has outerWidth 200." );
+ assert.strictEqual( $td.outerHeight(), 30, "outerHeight of td with border-box should include padding." );
+ assert.strictEqual( $textarea.outerHeight(), 6, "outerHeight of textarea with border-box should include padding and border." );
+} );
+
} )();