1. 開発者向けのウェブ技術
  2. CSS
  3. リファレンス
  4. プロパティ
  5. scroll-initial-target

このページはコミュニティーの尽力で英語から翻訳されました。MDN Web Docs コミュニティーについてもっと知り、仲間になるにはこちらから。

View in English Always switch to English

CSS scroll-initial-target プロパティ

利用可能性は限定的

この機能はベースラインではありません。最も広く使用されているブラウザーの一部で動作しません。

Want more support for this feature? Tell us why.

Experimental: これは実験的な機能です。
本番で使用する前にブラウザー互換性一覧表をチェックしてください。

scroll-initial-targetCSS のプロパティで、その親要素であるスクロールコンテナーが最初にレンダリングされた際に、スナップターゲットとなり得る要素を定義することができます。

構文

css
/* キーワード値 */
scroll-initial-target: none;
scroll-initial-target: nearest;
/* グローバル値 */
scroll-initial-target: inherit;
scroll-initial-target: initial;
scroll-initial-target: revert;
scroll-initial-target: revert-layer;
scroll-initial-target: unset;

none

この要素は、初期スクロール対象ではありません。

nearest

この要素は、最も近いスクロールコンテナーの親要素にとって、初期のスクロール対象となる可能性があります。

解説

scroll-initial-target プロパティを使用すると、親のスクロールスナップコンテナーが最初にレンダリングされた際に、スナップされるべき要素を定義できます。値を nearest に設定すると、その要素は、最も近い祖先のスクロールコンテナーがページ上に最初に表示された際にスナップされるべき潜在的なターゲットとして定義されます。

スクロールコンテナー内の複数の要素または擬似要素が nearest に設定されている場合、ツリー順で最初の要素が初期のスクロールスナップの対象となります。

初期値は none です。これは、スクロールスナップ可能な要素がデフォルトで初期スクロールターゲットではないことを意味します。また、要素に none を設定することで、その要素を明示的に初期スクロールターゲットから除外することもできます。

スクロールコンテナーの初期スクロール位置が、place-content の content-distribution プロパティと、子要素の scroll-initial-target の両方で設定される可能性がある場合、scroll-initial-target: nearest を指定している最初の子要素の設定が優先されます。

公式定義

初期値 none
適用対象すべての要素
継承 なし
計算値 the specified keyword
アニメーションの種類 アニメーション不可

形式文法

scroll-initial-target = 
none |
nearest
この構文は CSS Scroll Snap Module Level 2 による最新の標準を反映しています。すべてのブラウザーがすべての部分を実装しているわけではありません。サポート情報についてはブラウザーの互換性を参照してください。

scroll-initial-target の使用

下記の例では、scroll-initial-target の 2 つの値と、scroll-initial-target が設定された最初の要素がどのようにスナップされるかを示しています。

HTML

期待される効果を説明する段落に続き、5 つのコンテナーを配置します。

html
<p><code>none</code> を #4 のみに設定</p>
<div class="none">
 <div>1</div>
 <div>2</div>
 <div>3</div>
 <div class="set">4</div>
 <div>5</div>
</div>
<p><code>nearest</code> を #4 のみに設定</p>
<div class="nearest">
 <div>1</div>
 <div>2</div>
 <div>3</div>
 <div class="set">4</div>
 <div>5</div>
</div>
<p><code>nearest</code> を偶数番目の要素に設定</p>
<div class="nearest">
 <div>1</div>
 <div class="set">2</div>
 <div>3</div>
 <div class="set">4</div>
 <div>5</div>
</div>
<p><code>nearest</code> を奇数番目の要素に設定</p>
<div class="nearest">
 <div class="set">1</div>
 <div>2</div>
 <div class="set">3</div>
 <div>4</div>
 <div class="set">5</div>
</div>
<p><code>nearest</code> を奇数番目の要素に、<code>none</code> を #1 に設定</p>
<div class="nearest">
 <div class="set unset">1</div>
 <div>2</div>
 <div class="set">3</div>
 <div>4</div>
 <div class="set">5</div>
</div>

CSS

nearest の要素と none 要素をスクロールスナップコンテナーとして設定し、スナップされる要素を中央に配置します。

css
/* 親に mandatory の scroll-snap を設定 */
div.nearest,
div.none {
 scroll-snap-type: x mandatory;
}
/* 子の scroll-snap alignment の配置 */
div > div {
 scroll-snap-align: center;
 scroll-initial-target: always;
}

次に、.set クラスを持つすべての要素に対して、scroll-initial-targetnone または nearest に設定します。

css
.none .set,
.nearest .set.unset {
 scroll-initial-target: none;
}
.nearest .set {
 scroll-initial-target: nearest;
}
/* セットアップ */
body {
 height: 100%;
 display: flex;
 align-items: center;
 flex-flow: column nowrap;
 font-family: sans-serif;
 text-align: center;
}
div.nearest,
div.none {
 display: flex;
 overflow: auto;
 font-size: 3rem;
}
div div {
 width: 90%;
 min-width: 15rem;
 flex: none;
 outline: 1px solid #333333;
}
/* 色付け */
div > div:nth-child(even) {
 background-color: #87ea87;
}
div > div:nth-child(odd) {
 background-color: #87ccea;
}
p {
 margin: 1em 0 0;
}
@supports not (scroll-initial-target: nearest) {
 :root::before {
 content: "このブラウザーは、scroll-initial-target プロパティに対応していません。";
 background-color: wheat;
 display: block;
 text-align: center;
 padding: 1rem 0;
 }
}

結果

このプロパティの効果は、スクロールコンテナーがページに描画されたときに確認できます。

それぞれの行は、ツリー順で nearest が設定されている最初の要素(存在する場合)にスナップします。最後の例では、最初の要素の nearest 値を none に上書きしているため、nearest が適用される最初の要素は #3 となります。

仕様書

仕様書
CSS Scroll Snap Module Level 2
# propdef-scroll-initial-target

ブラウザーの互換性

関連情報

MDN の改良に協力

協力方法を知る

このページは MDN の貢献者によって に最終更新されました。

AltStyle によって変換されたページ (->オリジナル) /