| <!DOCTYPE html> |
| <html> |
| <link href="resources/flexbox.css" rel="stylesheet"> |
| <style> |
| body { |
| margin: 0; |
| } |
| .flexbox { |
| width: 600px; |
| } |
| .flexbox div { |
| height: 20px; |
| border: 0; |
| } |
| |
| .flexbox :nth-child(1) { |
| background-color: blue; |
| } |
| .flexbox :nth-child(2) { |
| background-color: green; |
| } |
| .flexbox :nth-child(3) { |
| background-color: red; |
| } |
| |
| .flex1 { |
| flex: 1; |
| } |
| .flex2 { |
| flex: 2; |
| } |
| .flex3 { |
| flex: 3; |
| } |
| .flex1-0-0 { |
| flex: 1 0 0px; |
| } |
| </style> |
| <script src="../../resources/testharness.js"></script> |
| <script src="../../resources/testharnessreport.js"></script> |
| <script src="../../resources/check-layout-th.js"></script> |
| <body onload="checkLayout('.flexbox')"> |
| <div id=log></div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="200" class="flex1"></div> |
| <div data-expected-width="200" class="flex1"></div> |
| <div data-expected-width="200" class="flex1"></div> |
| </div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="200" style="flex: .5;"></div> |
| <div data-expected-width="200" style="flex: .5;"></div> |
| <div data-expected-width="200" style="flex: .5;"></div> |
| </div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="300" class="flex3"></div> |
| <div data-expected-width="200" class="flex2"></div> |
| <div data-expected-width="100" class="flex1"></div> |
| </div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="250" class="flex1"></div> |
| <div data-expected-width="250" class="flex1"></div> |
| <div data-expected-width="100" class="flex-none" style="width: 100px"></div> |
| </div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="150" class="flex1"></div> |
| <div data-expected-width="150" class="flex1"></div> |
| <div data-expected-width="300" class="flex-none" style="width: 50%"></div> |
| </div> |
| |
| <!-- The first two boxes should fill the extra 300px evenly (each gets 150px extra). --> |
| <div class="flexbox"> |
| <div data-expected-width="150" class="flex1"></div> |
| <div data-expected-width="350" style="flex: 1 200px;"></div> |
| <div data-expected-width="100" class="flex-none" style="width: 100px"></div> |
| </div> |
| |
| <!-- Like the last test, except the middle box gets more space than the first box. --> |
| <div class="flexbox"> |
| <div data-expected-width="100" class="flex1"></div> |
| <div data-expected-width="400" style="flex: 2 33.333333%;"></div> |
| <div data-expected-width="100" class="flex-none" style="width: 100px"></div> |
| </div> |
| |
| <!-- Test some negative flexing. --> |
| <div class="flexbox"> |
| <div data-expected-width="200" style="flex: 1 1 300px;"></div> |
| <div data-expected-width="200" style="flex: 2 1 300px;"></div> |
| <div data-expected-width="200" style="flex: 3 1 300px;"></div> |
| </div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="250" style="flex: 1 1 300px;"></div> |
| <div data-expected-width="150" style="flex: 2 3 300px;"></div> |
| <div data-expected-width="200" class="flex-none" style="width: 200px"></div> |
| </div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="50" style="flex: 1 1 100px;"></div> |
| <div data-expected-width="250" style="flex: 1 1 500px;"></div> |
| <div data-expected-width="300" class="flex-none" style="width: 300px"></div> |
| </div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="50" style="flex: 1 1 100px;"></div> |
| <div data-expected-width="250" style="flex: 1 1 500px; margin-right: 300px;"></div> |
| </div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="50" style="flex: 1 1 100px;"></div> |
| <div data-expected-width="550" style="flex: 1 1 500px; padding-left: 300px;"></div> |
| </div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="50" style="flex: 1 1 100px;"></div> |
| <div data-expected-width="550" style="flex: 1 1 500px; border-left: 200px dashed orange; border-right: 100px dashed orange;"></div> |
| </div> |
| |
| <!-- Test some overflow cases. --> |
| <div class="flexbox"> |
| <div data-expected-width="600" style="flex: 0 100000000000000000000000000000000000000 600px;"></div> |
| <div data-expected-width="600" style="flex: 0 100000000000000000000000000000000000000 600px;"></div> |
| </div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="600" style="flex: 100000000000000000000000000000000000000 0 600px;"></div> |
| <div data-expected-width="600" style="flex: 0 100000000000000000000000000000000000000 600px;"></div> |
| <div data-expected-width="33554428" style="flex: 1 1 100000000000000000000000000000000000000px;"></div> |
| </div> |
| |
| <!-- Test flexitem borders. --> |
| <div class="flexbox"> |
| <div data-expected-width="250" class="flex1" style="border-left: 150px solid black"></div> |
| <div data-expected-width="250" class="flex1-0-0" style="border-right: 150px solid orange"></div> |
| <div data-expected-width="100" class="flex1-0-0"></div> |
| </div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="300" style="width: 100px; border: 100px solid black; flex: none;"></div> |
| <div data-expected-width="200" class="flex2"></div> |
| <div data-expected-width="100" class="flex1"></div> |
| </div> |
| |
| <!-- Test flexitem padding. --> |
| <div class="flexbox"> |
| <div data-expected-width="250" class="flex1" style="padding-left: 150px"></div> |
| <div data-expected-width="250" class="flex1-0-0" style="padding-right: 150px"></div> |
| <div data-expected-width="100" class="flex1-0-0"></div> |
| </div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="300" class="flex-none" style="width: 100px; padding: 100px"></div> |
| <div data-expected-width="200" class="flex2"></div> |
| <div data-expected-width="100" class="flex1"></div> |
| </div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="200" class="flex1" style="padding-left: 25%"></div> |
| <div data-expected-width="150" class="flex3"></div> |
| <div data-expected-width="250" class="flex-none" style="width: 100px; padding-right: 25%"></div> |
| </div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="200" class="flex1" style="padding-left: 50px; border-right: 50px solid black"></div> |
| <div data-expected-width="250" class="flex2" style="border-right: 50px solid orange"></div> |
| <div data-expected-width="150" class="flex1" style="padding-right: 50px;"></div> |
| </div> |
| |
| <!-- Test items with an intrinsic size. --> |
| <div class="flexbox"> |
| <div data-expected-width="120" class="flex1"> |
| <div style="width: 100px; height: 100%;"></div> |
| </div> |
| <div data-expected-width="240" class="flex2"></div> |
| <div data-expected-width="240" class="flex2"></div> |
| </div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="200" class="flex1-0-0"> |
| <div style="width: 100px; height: 100%;"></div> |
| </div> |
| <div data-expected-width="200" class="flex1"></div> |
| <div data-expected-width="200" class="flex1"></div> |
| </div> |
| |
| <div class="flexbox"> |
| <div data-expected-width="200" class="flex-auto"> |
| <div style="width: 100px;"></div> |
| </div> |
| <div data-expected-width="100" class="flex-auto"></div> |
| <div data-expected-width="300" class="flex-auto"> |
| <div style="width: 200px;"></div> |
| </div> |
| </div> |
| |
| <div class="flexbox" style="height: 60px; flex-flow: row wrap; position: relative;"> |
| <div data-offset-x="0" data-offset-y="0" style="position: absolute;"></div> |
| <div data-offset-x="0" data-offset-y="0" style="width: 700px;"></div> |
| </div> |
| |
| <!-- Test border/padding/margin on the flexbox itself. --> |
| <div data-expected-width="830" style="border: 10px solid; display: inline-block;"> |
| <div data-expected-width="700" style="padding-left: 10px; padding-right: 20px; border-left: 30px solid; border-right: 40px solid; margin-left: 50px; margin-right:60px;" class="flexbox"> |
| <div data-offset-x="100" data-expected-width="200" class="flex1"></div> |
| <div data-offset-x="300" data-expected-width="200" class="flex1"></div> |
| <div data-offset-x="500" data-expected-width="200" class="flex1"></div> |
| </div> |
| </div> |
| |
| </body> |
| </html> |