grid-repeat-auto-fill-fit-007-ref.html (5656B)
1 <!DOCTYPE HTML> 2 <!-- 3 Any copyright is dedicated to the Public Domain. 4 http://creativecommons.org/publicdomain/zero/1.0/ 5 --> 6 <html><head> 7 <meta charset="utf-8"> 8 <title>Reference: repeat(auto-fit) with grid-aligned abs.pos. with removed start/middle tracks</title> 9 <link rel="author" title="Mats Palmgren" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1237805"> 10 <style type="text/css"> 11 html,body { 12 color:black; background-color:white; font-size:16px; padding:0; margin:0; 13 } 14 15 .grid { 16 display: grid; 17 position: relative; 18 border: 1px solid; 19 grid-auto-rows: 30px; 20 grid-template-columns: [a] repeat(auto-fit, [b] 20px [c]) [d] 20px; 21 grid-gap: 2px; 22 width: 160px; 23 height: 30px; 24 } 25 26 .c1 { width: 160px; } 27 .c2 { width: 150px; } 28 .c3 { width: 140px; } 29 .p1 { padding-left:5px; } 30 31 .t2 { grid-template-columns: [a] repeat(auto-fit, [b] 20px [c]) [d]; } 32 33 x { 34 width: 18px; 35 border:1px solid; 36 background: grey; 37 } 38 a { 39 position: absolute; 40 left:0; top:0; height:3px; right:0; 41 background: cyan; 42 grid-column: -1 / auto; 43 } 44 b { 45 position: absolute; 46 left:0; bottom:0; height:3px; right:0; 47 background: brown; 48 grid-column: auto / -1; 49 } 50 c { 51 position: absolute; 52 left:0; bottom:5px; height:3px; right:0; 53 background: pink; 54 grid-column: -2 / auto; 55 } 56 d { 57 position: absolute; 58 left:0; bottom:10px; height:3px; right:0; 59 background: silver; 60 grid-column: 2 / -3; 61 } 62 e { 63 position: absolute; 64 left:0; bottom:15px; height:3px; right:0; 65 background: magenta; 66 grid-column: 3 / -1; 67 } 68 f { 69 position: absolute; 70 left:0; bottom:20px; height:3px; right:0; 71 background: orange; 72 grid-column: auto / -2; 73 } 74 75 x:first-child { 76 background: lime; 77 } 78 x:last-child { 79 background: blue; 80 } 81 82 .t1 x:last-child { 83 grid-column-end:-1; 84 } 85 86 .x5 x:first-child , .x3 x:first-child , .x2 x:first-child { 87 background: cyan; 88 } 89 90 .x5.t1 x:nth-child(2) , .x4 x:nth-child(2) , .x3 x:nth-child(2) { 91 background: purple; 92 } 93 94 95 float { float:left; margin-right:20px; } 96 97 .x5 { grid-template-columns: repeat(5,20px); } 98 .x4 { grid-template-columns: repeat(4,20px); } 99 .x3 { grid-template-columns: repeat(3,20px); } 100 .x2 { grid-template-columns: repeat(2,20px); } 101 102 .t1.x5 a { grid-column:5/auto; } 103 .c2.t1.x5 a , .c3.t1.x5 a { grid-column-start:-2; left:-2px; } 104 .c1.t1.x4 a { grid-column:4/auto; } 105 .c1.t1.x3 a { grid-column:3/auto; } 106 .c1.t1.x2 a { grid-column:2/auto; } 107 108 .t1.x5 c { grid-column:-3/-2; } 109 .t2.x5 c { grid-column:-2/-1; } 110 111 .c1.t1.x4 c { grid-column:-2/auto; } 112 .x4 c { grid-column:-2/-1; } 113 114 .c1.t1.x3 c, .c1.t1.x2 c { grid-column:-2/auto; } 115 .c2.t1.x3 c, .c3.t1.x3 c, .c2.t1.x2 c, .c3.t1.x2 c { grid-column:-2/-1; } 116 .t2.x3 c, .t2.x2 c { grid-column:-1/auto; } 117 118 .t1.x5 f , .t2.x4 f { grid-column:auto/4; } 119 .t2.x5 f { grid-column:auto/5; } 120 .t2 f { grid-column:auto/-1; } 121 122 .t2.x5 e , .t2.x4 e , .x3 e { grid-column:2/-1; } 123 .t1.x5 e , .c1.t1.x4 e, .c3.t1.x2 e { grid-column:2/-2; } 124 .c2.t1.x4 e, .c3.t1.x4 e { grid-column:2/-1; } 125 .c1.t1.x2 e { grid-column:2/auto; } 126 .c1.t1.x3 e , .x2 e { grid-column:2/3; } 127 128 .t2.x5 d, .t2.x4 d , .t1.x4 d { grid-column:2/-2; } 129 .t1.x3 d, .t1.x2 d { grid-column:2/3; } 130 .t2.x3 d { grid-column:2/-1; } 131 .t1.x2 d { grid-column:2/auto; } 132 .t2.x2 d { grid-column:2/3; } 133 134 .c1.t1 b , .c2.t1.x5 b , .c3.t1.x5 b { grid-column:auto/-2; } 135 136 </style> 137 </head> 138 <body> 139 140 <float> 141 <div class="grid c1 t1 x5"><x></x><x></x><x></x><x></x><a></a><b></b><c></c><d></d><e></e><f></f><x></x></div> 142 <div class="grid c2 t1 x5"><x></x><x></x><x></x><x></x><a></a><b></b><c></c><d></d><e></e><f></f></div> 143 <div class="grid c3 t1 x5"><x></x><x></x><x></x><x></x><a></a><b></b><c></c><d></d><e></e><f></f></div> 144 145 <div class="grid c1 t2 x5"><x></x><x></x><x></x><x></x><a></a><b></b><c></c><d></d><e></e><f></f><x></x></div> 146 <div class="grid c2 t2 x5"><x></x><x></x><x></x><x></x><a></a><b></b><c></c><d></d><e></e><f></f><x></x></div> 147 <div class="grid c3 t2 x5"><x></x><x></x><x></x><x></x><a></a><b></b><c></c><d></d><e></e><f></f><x></x></div> 148 149 <div class="grid c1 t1 x4"><x></x><x></x><x></x><a></a><b></b><d></d><e></e><f></f><x></x></div> 150 <div class="grid c2 t1 x4"><x></x><x></x><x></x><a></a><b></b><c></c><d></d><e></e><f></f><x></x></div> 151 <div class="grid c3 t1 x4"><x></x><x></x><x></x><a></a><b></b><c></c><d></d><e></e><f></f><x></x></div> 152 153 <div class="grid c1 t2 x4"><x></x><x></x><x></x><a></a><b></b><c></c><d></d><e></e><f></f><x></x></div> 154 <div class="grid c2 t2 x4"><x></x><x></x><x></x><a></a><b></b><c></c><d></d><e></e><f></f><x></x></div> 155 <div class="grid c3 t2 x4"><x></x><x></x><x></x><a></a><b></b><c></c><d></d><e></e><f></f><x></x></div> 156 157 <div class="grid c1 t1 x3"><x></x><x></x><a></a><b></b><d></d><e></e><f></f><x></x></div> 158 <div class="grid c2 t1 x3"><x></x><x></x><a></a><b></b><c></c><d></d><e></e><f></f><x></x></div> 159 <div class="grid c3 t1 x3"><x></x><x></x><a></a><b></b><c></c><d></d><e></e><f></f><x></x></div> 160 161 <div class="grid c1 t2 x3"><x></x><x></x><a></a><b></b><d></d><e></e><f></f><x></x></div> 162 <div class="grid c2 t2 x3"><x></x><x></x><a></a><b></b><d></d><e></e><f></f><x></x></div> 163 <div class="grid c3 t2 x3"><x></x><x></x><a></a><b></b><d></d><e></e><f></f><x></x></div> 164 </float> 165 166 <float> 167 <div class="grid c1 t1 x2"><x></x><a></a><b></b><f></f><x></x></div> 168 <div class="grid c2 t1 x2"><x></x><a></a><b></b><c></c><e></e><f></f><x></x></div> 169 <div class="grid c3 t1 x2"><x></x><a></a><b></b><c></c><e></e><f></f><x></x></div> 170 171 <div class="grid c1 t2 x2"><x></x><a></a><b></b><d></d><e></e><f></f><x></x></div> 172 <div class="grid c2 t2 x2"><x></x><a></a><b></b><d></d><e></e><f></f><x></x></div> 173 <div class="grid c3 t2 x2"><x></x><a></a><b></b><d></d><e></e><f></f><x></x></div> 174 </float> 175 176 </body> 177 </html>