<!DOCTYPE HTML> <!-- Any copyright is dedicated to the Public Domain. http://creativecommons.org/publicdomain/zero/1.0/ --> <html><head> <meta charset="utf-8"> <title>CSS Grid Test: abs pos static position (ancestor of grid container as abs.pos. CB)</title> <link rel="author" title="Mats Palmgren" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1151243"> <style type="text/css"> html,body { color:black; background-color:white; font-size:16px; padding:0; margin:0; } separator { clear:both; display:block; height:6px; } .grid { position: relative; display: grid; padding: 1px 3px 5px 7px; grid-template: 25px 33px 7px / 30px 51px 5px; margin-right: 4px; height: 100px; width: 100px; } .wrap { position: relative; float: left; padding: 3px 5px 7px 9px; border-style: solid; border-width: 1px 3px 5px 7px; border-block-start-color: blue; border-inline-start-color: lime; writing-mode: vertical-lr; direction:rtl; z-index:1; } abs1,abs2,abs3,abs4 { grid-area: 2 / 2 / 3 / 3; position: absolute; } abs1 { height:97px; top:-12px; left:-37px; background:lime; } abs2 { right:-18px; left:3px; background:pink; } abs3 { top: -20px; left:-35px; right:-26px; background:cyan; } abs4 { top:-6px; bottom:-53px; background:silver; } abs1::before { content:"1";} abs2::before { content:"2";} abs3::before { content:"3";} abs4::before { content:"4";} .hl { writing-mode: horizontal-tb; direction:ltr; } .hr { writing-mode: horizontal-tb; direction:rtl; } .vl { writing-mode: vertical-lr; } .vr { writing-mode: vertical-rl; } .vlr { writing-mode: vertical-lr; direction:rtl; } .vrl { writing-mode: vertical-rl; direction:ltr; } .hr abs3 { left:-24px; right:-37px; } .vl abs3, .vr abs3, .vrl abs3, .vlr abs3 { left:-30px; top:-14px; right:-49px; } .vr abs3, .vrl abs3 { left:-47px; right:-32px; } .vrl abs3 { top:-25px; } .hl abs2, .hr abs2 { top:-25px; } .hl abs2 { left:-43px; } .hr abs2 { left:-32px; right:-29px; } .vl abs2, .vr abs2, .vrl abs2, .vlr abs2 { left:-38px; right:-41px; } .vr abs2, .vrl abs2 { left:-55px; right:-24px; } .vrl abs2 { top:-16px; } .hr abs1 { left: 94px; } .vl abs1, .vr abs1, .vrl abs1, .vlr abs1 { top:-6px; left:-32px; } .vr abs1, .vrl abs1 { left:71px; } .vrl abs1 { top:-17px; } .hl abs4 { left:51px; } .hr abs4 { left:10px; } .vl abs4, .vr abs4, .vrl abs4, .vlr abs4 { top:0px; bottom:-41px; left:-25px; } .vr abs4, .vrl abs4 { left:68px; } .vrl abs4 { top:-11px; bottom:-29px; } </style> </head> <body> <script> document.body.style.display="none"; var wm = [ "hl", "hr", "vl", "vr", "vlr", "vrl" ]; for (var i = 0; i < wm.length; ++i) { for (var j = 0; j < wm.length; ++j) { var div = document.createElement("div"); div.className = "grid " + wm[i]; div.appendChild(span = document.createElement("span")); span.appendChild(document.createTextNode("A")); div.appendChild(document.createElement("abs1")); div.appendChild(span = document.createElement("span")); span.appendChild(document.createTextNode("BC")); div.appendChild(document.createElement("abs3")); div.appendChild(document.createElement("abs4")); var wrap = document.createElement("div"); wrap.className = "wrap "; wrap.appendChild(div); document.body.appendChild(wrap) } document.body.appendChild(document.createElement("separator")); } document.body.style.display=""; </script> </body> </html>