1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141
|
<!DOCTYPE html>
<title>cssom-view - scroll-behavior: smooth</title>
<meta name="timeout" content="long">
<link rel="author" title="Rune Lillesveen" href="mailto:futhark@chromium.org">
<link rel="help" href="https://drafts.csswg.org/cssom-view/#smooth-scrolling">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<style>
.filler { height: 10000px }
.smooth {
scroll-behavior: smooth;
}
#scrollable {
overflow: scroll;
width: 100px;
height: 100px;
}
</style>
<div id="testContainer">
<div id="scrollable">
<div class="filler"></div>
</div>
<div class="filler"></div>
</div>
<script>
test(() => {
scrollable.scrollTo(0, 5000);
assert_equals(scrollable.scrollTop, 5000, "Initially scrolls instantly");
scrollable.scrollTo(0, 0);
scrollable.className = "smooth";
scrollable.scrollTo(0, 5000);
assert_less_than(scrollable.scrollTop, 5000, "scroll-behavior:smooth should not scroll instantly");
scrollable.className = "";
scrollable.scrollTo(0, 0);
}, "scroll-behavior: smooth on DIV element");
test(() => {
window.scrollTo(0, 5000);
assert_equals(window.scrollY, 5000, "Initially scrolls instantly");
window.scrollTo(0, 0);
document.documentElement.className = "smooth";
assert_less_than(window.scrollY, 5000, "scroll-behavior:smooth should not scroll instantly");
document.documentElement.className = "";
window.scrollTo(0, 0);
}, "HTML element scroll-behavior should propagate to viewport");
test(() => {
window.scrollTo(0, 5000);
assert_equals(window.scrollY, 5000, "Initially scrolls instantly");
window.scrollTo(0, 0);
document.body.className = "smooth";
window.scrollTo(0, 5000);
assert_equals(window.scrollY, 5000, "scroll-behavior:smooth on BODY should scroll viewport instantly");
document.body.className = "";
window.scrollTo(0, 0);
}, "BODY element scroll-behavior should not propagate to viewport");
var instantHistoryNavigationTest =
async_test("Instant scrolling while doing history navigation.");
var smoothHistoryNavigationTest =
async_test("Smooth scrolling while doing history navigation.");
function instant() {
document.documentElement.className = "";
document.body.className = "";
window.scrollTo(0, 0);
var p = document.createElement("pre");
p.textContent = new Array(1000).join("newline\n");
var a = document.createElement("a");
a.href = "#";
a.name = "foo";
a.textContent = "foo";
p.appendChild(a);
document.body.appendChild(p);
window.onhashchange = function() {
window.onhashchange = function() {
instantHistoryNavigationTest.step(function() {
assert_equals(location.hash, "", "Shouldn't be scrolled to a fragment.");
assert_equals(window.scrollY, 0, "Shouldn't be scrolled back to top yet.");
});
p.remove();
instantHistoryNavigationTest.done();
smooth();
}
instantHistoryNavigationTest.step(function() {
assert_equals(location.hash, "#foo", "Should be scrolled to a fragment.");
assert_not_equals(window.scrollY, 0, "Shouldn't be scrolled to top anymore.");
});
history.back();
}
instantHistoryNavigationTest.step(function() {
assert_equals(window.scrollY, 0, "Should be scrolled to top.");
assert_equals(location.hash, "", "Shouldn't be scrolled to a fragment.");
});
location.hash = "foo";
};
instant();
function smooth() {
document.documentElement.className = "";
document.body.className = "";
window.scrollTo(0, 0);
var p = document.createElement("pre");
p.textContent = new Array(1000).join("newline\n");
var a = document.createElement("a");
a.href = "#";
a.name = "bar";
a.textContent = "bar";
p.appendChild(a);
document.body.appendChild(p);
window.onhashchange = function() {
window.onhashchange = function() {
smoothHistoryNavigationTest.step(function() {
assert_equals(location.hash, "", "Shouldn't be scrolled to a fragment.");
assert_not_equals(window.scrollY, 0, "Shouldn't be scrolled back to top yet.");
});
p.remove();
smoothHistoryNavigationTest.done();
}
smoothHistoryNavigationTest.step(function() {
assert_equals(location.hash, "#bar", "Should be scrolled to a fragment.");
assert_not_equals(window.scrollY, 0, "Shouldn't be scrolled to top anymore.");
});
history.back();
}
smoothHistoryNavigationTest.step(function() {
assert_equals(window.scrollY, 0, "Should be scrolled to top.");
assert_equals(location.hash, "", "Shouldn't be scrolled to a fragment.");
});
location.hash = "bar";
document.documentElement.className = "smooth";
};
testContainer.style.display = "none";
</script>
|