ページ内リンクの移動先が固定メニューの高さ分、上にずれる

サイトによってはページ上部に固定メニューを使っているケースもあります。こういう環境では、ページ内リンクをクリックして飛んだ先の要素が全体に上へずれることがあります。これは固定メニューの設定で利用されるcssの「position: fixed」が原因と考えられます。

解決策

解決策は、cssで固定メニュー分の高さをpadding-topに代入し、同時にmargin-topで同じ高さを差し引くのが最も簡単です。ロジック的には移動先の要素の高さをpadding-topで広げ、その際に発生する要素上部の空白をmargin-topで差し引くというものです。

padding-topのみでも上手く移動できますが、それぞれの移動先の要素の上部に空白が発生するため、cssを作成した当初に想定した枠組みとは少々異なるものになってしまいます。そのため、margin-topで差し引いて空白を埋めます。

他にjavascriptで変更させるやり方もありますが、記述する上ではcssのほうが断然容易です。当サイトでは以下のように記入しています。

CSS
1
2
3
4
5
6
<style>
[id*="item"] {
margin-top: -48px !important;
padding-top: 48px !important;
}
</style>

二行目の*印はアスタリスクと呼ばれる正規表現の一つで、「item」を含むidという意味です。当サイトでは移動先要素のidに「item1」「item2」というふうに連番で指定しており、これら全てに適用させるためにアスタリスクを使用しています。もちろん「#item1,#item2,#item3」といったカンマで区切る書式でも動作します。

三行目、四行目の「!important」は、無くても動作するなら必要ありません。スタイルシートには優先順位というものがあり、同一ファイル内では後から指定したものが優先されます。「!important」はその順位を無視して「プロパティ: 値 !important;」という設定ごとに優先させることができます。その他、通常のスタイルより優先されるクラスセレクタやIDセレクタといったものがありますが、ここでは割愛します。