scroll()
Limited availability
This feature is not Baseline because it does not work in some of the most widely-used browsers.
Experimental: これは実験的な機能です。
本番で使用する前にブラウザー互換性一覧表をチェックしてください。
scroll()
は CSS 関数で、 animation-timeline
と共に使用することができます。 animation-timeline
はスクロール可能な要素 (scroller) とスクロールバーの軸を示し、現在の要素をアニメーションさせるための無名スクロール進行タイムラインを提供します。スクロール進行タイムラインは、スクローラーを上下(または左右)にスクロールすることで進行します。スクロール範囲内の位置は進行のパーセント値に変換されます。先頭は 0% で、末尾は 100% です。
メモ: 示された軸がスクロールバーを持たない場合、アニメーションタイムラインは非アクティブになります(進行がゼロになります)。
メモ: scroll()
を使用するたびに、ウェブアニメーション API に ScrollTimeline
の固有のインスタンスが対応付けられます。
構文
/* 引数を設定しない関数 */
animation-timeline: scroll();
/* スクローラー要素を選択する値 */
animation-timeline: scroll(nearest); /* 既定 */
animation-timeline: scroll(root);
animation-timeline: scroll(self);
/* 軸を選択する値 */
animation-timeline: scroll(block); /* 既定 */
animation-timeline: scroll(inline);
animation-timeline: scroll(y);
animation-timeline: scroll(x);
/* スクローラーと軸を指定する例 */
animation-timeline: scroll(block nearest); /* 既定 */
animation-timeline: scroll(inline root);
animation-timeline: scroll(x self);
引数
形式文法
例
無名スクロール進行タイムラインの設定
この例では、 #square
要素は scroll()
関数を使用してアニメーションされる要素に適用される無名スクロール進行タイムラインを使ってアニメーションされます。
この具体的な例でのタイムラインは、ブロック方向のスクロールバーから、(任意の)スクロールバーを持つ最も近い親要素によって指定されたものです。
HTML
例の HTML は下記の通りです。
<div id="container">
<div id="square"></div>
<div id="stretcher"></div>
</div>
CSS
下記の CSS では、animation-timeline
プロパティで指定されたタイムラインに従って、交互に回転する正方形を定義しています。
この場合、タイムラインは scroll(block nearest)
によって指定されます。これはスクロールバーを保有する最も近い祖先要素のブロック方向のスクロールバーを選択することを意味しています。
メモ: 実は block
と nearest
は既定値なので、scroll()
だけを使用することができました。
#square {
background-color: deeppink;
width: 100px;
height: 100px;
margin-top: 100px;
position: absolute;
bottom: 0;
animation-name: rotateAnimation;
animation-duration: 1ms; /* Firefox では、アニメーションを適用するために必要 */
animation-direction: alternate;
animation-timeline: scroll(block nearest);
}
@keyframes rotateAnimation {
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
}
コンテナー用の CSS では、コンテナーの高さを 300px に設定し、コンテナーがはみ出した場合に垂直スクロールバーを作成するようにも設定しています。 "stretcher" の CSS では、ブロックの高さを 600px に設定し、コンテナー要素を強制的にオーバーフローさせます。 この 2 つを組み合わせることで、コンテナーに垂直スクロールバーを確実に設置し、無名スクロール進行タイムラインのソースとして使用することができます。
#container {
height: 300px;
overflow-y: scroll;
position: relative;
}
#stretcher {
height: 600px;
}
結果
スクロールすると、正方形の要素がアニメーションします。
仕様書
Specification |
---|
Scroll-driven Animations # scroll-notation |
ブラウザーの互換性
BCD tables only load in the browser