SafariのURLメニュー部分も考慮できるCSSの単位「dvh」

iOS 15.4のSafariからは新しい単位が追加されました。
その中でも「dvh」という単位が非常に便利で、いままでiOS Safariで高さ100%の状態を指定するのはかなり面倒でしたが、それが解消されます。
iOS SafariのURLメニュー問題
iOS Safariでは、下にスクロールするとメニューバーが小さくなって隠れ、上にスクロールするとメニューバーが大きくなります。

100vhという指定の仕方もありますが、これだとメニューバーが隠れた状態の高さ100%になるので、メニューバーが表示された状態での高さ100%を指定するのは面倒でした。
「dvh」単位の使い方
高さの指定時に単位として「dvh」を指定するだけで、メニューなどのUI状態も考慮した高さ100%を実現できます。
height: 100dvh;ただし、この単位はiOS 15.4以降のSafariでしか対応していないので、その前に従来の単位で高さ指定をしておきます。
height: 100vh;
height: 100dvh;これならiOS Safariでは「100dvh」が適用されて、それ以外のブラウザでは「100dvh」の指定が読み込まれず、その前に指定されてある「100vh」が適用されます。
dvh以外の単位
dvh以外にもいくつかの単位が追加されています。
追加された単位には先頭に「sv○」「lv○」「dv○」が付いていて、それぞれ下記の意味があります。
- sv○:メニューなどのUI表示時の○○
- lv○:メニューなどのUI非表示時の○○
- dv○:メニューなどのUI現在状態の○○
| 単位 | 意味 | 備考 |
|---|---|---|
| svw | メニューなどのUI表示時の「横幅」 | |
| lvw | メニューなどのUI非表示時の「横幅」 | |
| dvw | メニューなどのUI現在状態の「横幅」 | |
| svh | メニューなどのUI表示時の「高さ」 | |
| lvh | メニューなどのUI非表示時の「高さ」 | |
| dvh | メニューなどのUI現在状態の「高さ」 | |
| svmin | svwとsvhの小さい方 | |
| lvmin | lvwとlvhの小さい方 | |
| dvmin | dvwとdvhの小さい方 | |
| svmax | svwとsvhの大きい方 | |
| lvmax | lvwとlvhの大きい方 | |
| dvmax | dvwとdvhの大きい方 | |
| svi | メニューなどのUI表示時の「インライン方向のサイズ」 | viewport inlineの「vi」? |
| lvi | メニューなどのUI非表示時の「インライン方向のサイズ」 | |
| dvi | メニューなどのUI現在状態の「インライン方向のサイズ」 | |
| svb | メニューなどのUI表示時の「ブロック方向のサイズ」 | viewport blockの「vb」? |
| lvb | メニューなどのUI非表示時の「ブロック方向のサイズ」 | |
| dvb | メニューなどのUI表示時の「ブロック方向のサイズ」 |
現状はSafariのみですが、今後他のブラウザでも対応されていきそうです。


Visual Studio CodeでDart Sassのコンパイルができる拡張機能「DartJS Sass Compiler and Sass Watcher」
Visual Studio CodeでToDoコメントを一覧で表示する拡張機能「Todo Tree」
CSSで1行で簡単にスムーススクロールを実装できる「scroll-behavior」プロパティ
サイトを運営する時必ず登録しておきたいGoogle Search Console(サーチコンソール)の登録方法
効率的なマークアップが出来るようになるEmmetでHTMLを書く時の基本
Visual Studio CodeからFTPソフトのTransmitを使用する拡張機能「Transmit」
「epel-release」インストール後にyum installで「Cannot retrieve metalink for repository」と表示される場合の対処法
Vue.jsのv-forで生成した要素をクリックするたびに、classをトグルで付け外しする方法
TwitterとFacebook用のOGP設定方法と表示確認方法
iTerm2で「Use System Window Restoration Setting」を設定しているとアラートが表示されて機能しない
Google Chromeのサイト内検索(カスタム検索)機能を別のプロファイルに移行する方法
iPadで入力モードを切り替えずに数字や記号をすばやく入力する方法
iPhoneやiPadでYouTubeの再生速度を3倍速や4倍速にする方法
Keynoteで有効にしているはずのフォントが表示されない現象
MacのKeynoteにハイライトされた状態でコードを貼り付ける方法
AirPodsで片耳を外しても再生が止まらないようにする方法
iTerm2でマウスやトラックパッドの操作を設定できる環境設定の「Pointer」タブ
DeepLで「インターネット接続に問題があります」と表示されて翻訳できないときに確認すること
Ulyssesの「第2のエディタ」表示を使って2つのシートを横並びに表示する
かゆいところに手が届く「Supercharge」でMac環境を便利にカスタマイズする
超軽量なコードエディタ 「Zed」をサブエディタとして活用する
Bartender 6で追加されたWidgets機能で自作メニューバーアイテムを簡単に作成する
Googleカレンダーを便利に活用するための小技集(祝日だけを表示・月末の繰り返しイベントを追加)
Obsidianを使った「自己流PKM」で行う知識トレーニング
テキストエディタ・ノートアプリ関連のショートカットキーをKeyboard Maestroで統一する
Path Finderを使ってキーボードだけでファイル操作する方法(応用編)
macOSのコマンドパレット比較!SpotlightとAlfred、Raycastどれを使えばいい?
1つのノートアプリにすべて集約するのをやめた理由|2025年時点のノートアプリの使い分け