CSSでスクロールバーの有無によるがたつきをなくす ― 2022年12月09日 09時42分
この記事はCSS Advent Calendar 2022の9日目の分です。
CSSのボックスモデルにおいては、ボーダーの内辺とパディングの外辺の間にスクロールバーが配置されます。最近はどのOSでもオーバーレイスクロールバー(スクロールバーが内容の前面に覆いかぶさるようなもの)が主流となり、スクロールバーが存在してもしなくても内容の幅が変わらないようになっています。一方、クラシックスクロールバー(スクロールバーが常に表示されるようなもの)が使われる環境では、overflow: auto
な要素において内容がはみ出すときとはみ出さないときで内容の幅が変わってきます。
クラシックスクロールバーが使われる環境でも内容の幅を一定に保ちたいという場合は、scrollbar-gutter
プロパティを使います。scrollbar-gutter: stable
を指定すれば、スクロールバーが表示されないときでもスクロールバーと同じだけの領域が確保され、内容の幅はその分狭くなります。左右中央に配置したいのにスクロールバーの領域の分だけずれて困るというときは、scrollbar-gutter: stable both-edges
を指定することで、左右どちらにもスクロールバーと同じだけの領域が確保されます。
scrollbar-gutter
プロパティはoverflow: hidden
な要素にも適用されますが、overflow: visible
な要素には適用されません。また、scrollbar-gutter
プロパティの効果は、縦スクロールバー(縦書きなら横スクロールバー)にのみ影響します。
オーバーレイスクロールバーが使われる環境では、scrollbar-gutter: stable
の効果はありません。
使用事例
使用事例としては、@about_hiroppyさんの紹介している「HTMLのdialog
要素によるモーダルダイアログが開いているときに、背景の文書をスクロールさせない」というのが考えられます(scrollbar-gutter
プロパティを指定した例と指定しなかった例)。
html {
scrollbar-gutter: stable;
}
html:has(dialog:modal) {
overflow: hidden;
}
クラシックスクロールバーが使われる環境では、文書をスクロールさせないためにoverflow: hidden
を指定すると、スクロールバーが消えて文書の内容ががたついてしまいます。scrollbar-gutter: stable
をあらかじめ指定しておけば、スクロールバーが消えてもその分の領域が確保され続けるので、文書の内容ががたつきません。
最近のコメント