Source code

Revision control

Copy as Markdown

Other Tools

Test Info: Warnings

  • This test has a WPT meta file that expects 1 subtest issues.
  • This WPT test may be referenced by the following Test IDs:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title> CSS Scroll Snap 2 Test: scroll-initial-target*</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/dom/events/scrolling/scroll_support.js"></script>
</head>
<body>
<style>
#space {
width: 1000px;
height: 1000px;
border: solid 1px red;
}
#scroller {
width: 400px;
height: 400px;
overflow: hidden;
border: solid 1px blue;
position: absolute;
}
#target {
width: 100px;
height: 100px;
background-color: pink;
scroll-initial-target: nearest;
position: absolute;
top: 400px;
left: 400px;
}
</style>
<div id="scroller">
<div id="space"></div>
<div id="target"></div>
</div>
<script>
promise_test(async (t) => {
await waitForCompositorCommit();
assert_equals(scroller.scrollTop, 400,
"scroller is vertically scrolled to target");
assert_equals(scroller.scrollLeft, 400,
"scroller is horizontally scrolled to target");
target.style.scrollSnapAlign = "center";
await waitForCompositorCommit();
assert_equals(scroller.scrollTop, 250,
"scroller is vertically aligned to target's center");
assert_equals(scroller.scrollLeft, 250,
"scroller is horizontally aligned to target's center");
target.style.scrollSnapAlign = "end";
await waitForCompositorCommit();
assert_equals(scroller.scrollTop, 100,
"scroller is vertically aligned to target's bottom");
assert_equals(scroller.scrollLeft, 100,
"scroller is horizontally aligned to target's right");
target.style.scrollSnapAlign = "start";
await waitForCompositorCommit();
assert_equals(scroller.scrollTop, 400,
"scroller is vertically aligned to target's top");
assert_equals(scroller.scrollLeft, 400,
"scroller is horizontally aligned to target's left");
}, "scroll-initial-target aligns with scroll-snap-align");
</script>
</body>
</html>