Source code

Revision control

Copy as Markdown

Other Tools

Test Info:

<!DOCTYPE html>
<style>
body { margin: 0; }
*:hover { background: lime !important; }
</style>
<div id="multicol" style="columns:4; column-gap:0; column-fill:auto; width:400px; height:100px; background: yellow">
<div id="before" style="height: 50px; background: gray"></div>
<div id="transform" style="transform: translateY(20px)">
<div id="target1" style="height: 100px; background: green"></div>
<div id="target2" style="height: 200px; background: blue"></div>
</div>
<div id="after" style="height: 50px; background: gray"></div>
</div>
<div id="log" style="margin-top:100px;"></div>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script>
test(()=> { assert_equals(document.elementFromPoint(50, 40), before); }, "before");
test(()=> { assert_equals(document.elementFromPoint(50, 60), multicol); }, "between before and transform");
test(()=> { assert_equals(document.elementFromPoint(50, 80), target1); }, "target1");
test(()=> { assert_equals(document.elementFromPoint(50, 110), target1); }, "target1 overflow");
test(()=> { assert_equals(document.elementFromPoint(150, 10), multicol); }, "top gap in column 2");
test(()=> { assert_equals(document.elementFromPoint(150, 30), target1); }, "target1 in column 2 top");
test(()=> { assert_equals(document.elementFromPoint(150, 60), target1); }, "target1 in column 2 bottom");
test(()=> { assert_equals(document.elementFromPoint(150, 80), target2); }, "target2 in column 2");
test(()=> { assert_equals(document.elementFromPoint(150, 110), target2); }, "target2 in column 2 overflow");
test(()=> { assert_equals(document.elementFromPoint(250, 10), multicol); }, "top gap in column 3");
test(()=> { assert_equals(document.elementFromPoint(250, 30), target2); }, "target2 in column 3 top");
test(()=> { assert_equals(document.elementFromPoint(250, 110), target2); }, "target2 in column 3 bottom");
test(()=> { assert_equals(document.elementFromPoint(350, 10), multicol); }, "top gap in column 4");
test(()=> { assert_equals(document.elementFromPoint(350, 30), target2); }, "target2 in column 4 top");
test(()=> { assert_equals(document.elementFromPoint(350, 60), target2); }, "target2 in column 4 bottom");
test(()=> { assert_equals(document.elementFromPoint(350, 80), after); }, "after");
test(()=> { assert_equals(document.elementFromPoint(350, 110), document.documentElement); }, "below");
</script>