CSS中央寄せテクニックとして、
position: absolute;
left: 0;
right: 0;
margin: auto;
はあまりにも有名だが、
親要素より大きな要素を中央寄せしようとすると左寄せになってしまう問題がある。
data:image/s3,"s3://crabby-images/31e6a/31e6a74e6bec68166fa023c3e782e823661817e3" alt="スクリーンショット 2019-11-30 18.31.59.png"
この問題を解消するためのCSSの書き方が以下になります。
css
position: absolute;
left: -100%;
right: -100%;
margin: auto;
data:image/s3,"s3://crabby-images/22f9a/22f9aa9c7aa4c50e9ebc3c7234705dd5fa457058" alt="スクリーンショット 2019-11-30 18.39.28.png"
親:400px - 子:600px = -200px
-200px / 2 = -100px
left: -100px;
right: -100px
こんなときに使える
コンテナー内にあるセクション要素の背景が、コンテナーを突き抜けてるようなデザインだった場合、いちいちコンテナー内からセクション要素を外に出す必要がなくなる。
css
section2 {
position: relative;
&::before {
content: '';
display: block;
position: absolute;
z-index: -1;
left: -100%;
right: -100%;
margin: auto;
width: 100vw;
height: 100%;
background: url(bg.jpg);
}
}