自動化無しに生活無し

WEB開発関係を中心に備忘録をまとめています

position:relativeとabsoluteとtransform:translateを使ったセンタリング【どんな画面幅でも中央に配置する】

thumbnail

例えば、サイトのタイトルなど、どんな状況でも必ず中央に配置したい場合があるだろう。

そういう時は、positiontransform:translateを使用することで解決できる。

ソースコード

まずは下記のソースコードを動かしてもらいたい。

`<!DOCTYPE html>
<html lang="ja">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width,initial-scale=1">
    <title>Hello World test!!</title>

<style>
body{
    /* ブラウザのデフォルトでmarginが付いているので消しておく。*/
    margin:0;
}
.content_area {
    position:relative;

    /* content_areaの高さをブラウザの縦幅全開まで指定 */
    height:100vh;

    background:deepskyblue;
}

.content{
    position:absolute;

    top:50%;
    left:50%;
    transform:translate(-50%, -50%);

    background:orange;
}
</style>


</head>
<body>

    <div class="content_area">
        <div class="content">HelloWorld</div>
    </div>

</body>
</html>

動かすとこうなる。

説明

まず、親要素の.content_areaにはheight:100vh;position:relative;を指定しておく。

position:absolute;を指定した子要素はposition:relative;を指定した親要素の左上の位置を起点とすることができる。

子要素は親要素の左上を起点として、左から50%、上から50%の位置に配置される。ちなみに、この50%というのは親要素の50%である。(下記図の緑枠の場所)

しかし、これでは要素の配置が若干右下にずれてしまう。そこでtransform:translate()で再配置を行う。

translateの50%は子要素自身に対しての基準となっている。つまり、子要素のX軸方向、Y軸方向に対してそれぞれ-50%になる。

すると、画面の中央に子要素の中心が配置されるようになる。(下記図のオレンジ枠)

positionに関しては下記も参考にすると良いだろう。

参照元

余談

ちなみに参照元のサイトを含め、HTMLやCSSの解説をしているサイトのほとんどでは、-web-kitなどのベンダープレフィックスが使用されている。

しかし、現行のブラウザではほとんどのCSSプロパティにおいて、ベンダープレフィックスは無くても正常に動作する。ベンダープレフィックスの詳細は下記Qiitaを参照すると良いだろう。

https://qiita.com/xrxoxcxox/items/3e0e34003a45d3618b29

スポンサーリンク