forked from mirrors/gecko-dev
While looking at the backout, I noticed table parts relied on reframing on abspos-container-ness changes in a subtle way, see the test, which fails with the first patch of this bug applied without these changes. Make the NS_FRAME_CAN_HAVE_ABSPOS_CHILDREN mean the same for table parts as for everything else. Instead, keep the registration status on each relevant frame class individually. Depends on D169127 Differential Revision: https://phabricator.services.mozilla.com/D170969
30 lines
935 B
HTML
30 lines
935 B
HTML
<!doctype html>
|
|
<meta charset="utf-8">
|
|
<title>Dynamic position change in table cell with abspos child</title>
|
|
<link rel="help" href="https://drafts.csswg.org/css-position-3/#position-property">
|
|
<link rel="help" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1815552">
|
|
<link rel="author" title="Emilio Cobos Álvarez" href="mailto:emilio@crisal.io">
|
|
<link rel="author" title="Mozilla" href="https://mozilla.org">
|
|
<link rel="match" href="abspos-container-change-dynamic-001-ref.html">
|
|
<table>
|
|
<tbody>
|
|
<tr>
|
|
<td>A</td>
|
|
<td id="target">B</td>
|
|
</tbody>
|
|
</table>
|
|
<script>
|
|
let target = document.getElementById("target");
|
|
target.getBoundingClientRect();
|
|
target.style.position = "relative";
|
|
let abspos = document.createElement("div");
|
|
abspos.style = `
|
|
position: absolute;
|
|
top: 0;
|
|
left: 0;
|
|
width: 100px;
|
|
height: 100px;
|
|
background-color: lime;
|
|
`;
|
|
target.appendChild(abspos);
|
|
</script>
|