本記事では、position:absoluteを使って中央寄せする方法について解説しています。
HTML/CSSの学習におすすめ書籍
1冊ですべて身につくHTML&CSSとWebデザイン入門講座
data:image/s3,"s3://crabby-images/c3ad5/c3ad5c80739fdc3529fff42ec2504a91b49d602d" alt=""
メリット
- HTMLとCSSの基本が体系的に学べる
- Webデザインの基本が学べる
- 1つのWebサイトを作りながら学べる
data:image/s3,"s3://crabby-images/75b75/75b7553cd2e7a9db3ba25801124880b4e10baa51" alt=""
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
Amazon Kindle Unlimitedに登録すると、月額980円で読み放題だからオススメだよ!
data:image/s3,"s3://crabby-images/8bc2f/8bc2f319e158a1409e96e562ba94005d162ed315" alt=""
data:image/s3,"s3://crabby-images/8bc2f/8bc2f319e158a1409e96e562ba94005d162ed315" alt=""
data:image/s3,"s3://crabby-images/8bc2f/8bc2f319e158a1409e96e562ba94005d162ed315" alt=""
初回30日間は無料だから、まだ登録したことのない人はぜひ試してみてね!
全プログラマー必見!
変数名/関数名にもう悩まない!
変数名/関数名にもう悩まない!
リーダブルコード
data:image/s3,"s3://crabby-images/58149/58149339a4d905ca2bb398ffda5510b8d882cab7" alt=""
data:image/s3,"s3://crabby-images/58149/58149339a4d905ca2bb398ffda5510b8d882cab7" alt=""
メリット
- 美しいコードが書けるが自然と書けるようになる
- 他の開発者が理解しやすいコードになる
著:Dustin Boswell, 著:Trevor Foucher, 解説:須藤 功平, 翻訳:角 征典
¥2,640 (2023/07/23 02:48時点 | Amazon調べ)
data:image/s3,"s3://crabby-images/75b75/75b7553cd2e7a9db3ba25801124880b4e10baa51" alt=""
data:image/s3,"s3://crabby-images/75b75/75b7553cd2e7a9db3ba25801124880b4e10baa51" alt=""
目次
position:absoluteで中央寄せする手順
data:image/s3,"s3://crabby-images/8bc2f/8bc2f319e158a1409e96e562ba94005d162ed315" alt=""
data:image/s3,"s3://crabby-images/8bc2f/8bc2f319e158a1409e96e562ba94005d162ed315" alt=""
data:image/s3,"s3://crabby-images/8bc2f/8bc2f319e158a1409e96e562ba94005d162ed315" alt=""
先輩!position:absoluteで中央寄せする方法を教えてください!
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
了解!3つの手順に分けて解説するね!
サンプルコード
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<link rel="stylesheet" href="style.css" />
</head>
<body>
<div class="parent">
<p class="children">SAMPLE</p>
</div>
</body>
</html>
.parent {
background-color: brown;
width: 200px;
height: 200px;
}
.children {
color: white;
}
data:image/s3,"s3://crabby-images/325a0/325a069f143b5d1513a748991f9515c03fbc8bb5" alt="サンプルコードの表示結果"
data:image/s3,"s3://crabby-images/325a0/325a069f143b5d1513a748991f9515c03fbc8bb5" alt="サンプルコードの表示結果"
手順1:親要素にposition:relative、子要素にposition:absoluteを指定
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
まず始めに起点となる親要素にposition:relativeを指定し、中央寄せしたい子要素にposition:absoluteを指定するよ!
.parent {
background-color: brown;
width: 200px;
height: 200px;
/* 追加 */
position: relative;
}
.children {
color: white;
/* 追加 */
position: absolute;
}
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
この状態で、下準備は完了です!次から子要素を動かして中央寄せしていきます!
手順2:中央寄せ①
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
position:absoluteを指定した子要素に中央寄せする記述を追加します!
.parent {
background-color: brown;
width: 200px;
height: 200px;
position: relative;
}
.children {
color: white;
position: absolute;
/* 追加 */
top: 50%;
left: 50%;
}
data:image/s3,"s3://crabby-images/90310/903104354f6cc32accf669c7ddb95bfe004f0d27" alt="中央寄せ①の表示結果"
data:image/s3,"s3://crabby-images/90310/903104354f6cc32accf669c7ddb95bfe004f0d27" alt="中央寄せ①の表示結果"
data:image/s3,"s3://crabby-images/8bc2f/8bc2f319e158a1409e96e562ba94005d162ed315" alt=""
data:image/s3,"s3://crabby-images/8bc2f/8bc2f319e158a1409e96e562ba94005d162ed315" alt=""
data:image/s3,"s3://crabby-images/8bc2f/8bc2f319e158a1409e96e562ba94005d162ed315" alt=""
中央よりも少し右下にずれていませんか?
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
いい所に気が付いたね!ここでの中央寄せは、子要素の左上(画像の黒丸)を起点に中央寄せしているから、まだ完璧な中央寄せになっていないんだ!
手順3:中央寄せ②
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
最後に子要素本体を左に50%・上に50%移動する記述を追加します!
.parent {
background-color: brown;
width: 200px;
height: 200px;
position: relative;
}
.children {
color: white;
position: absolute;
top: 50%;
left: 50%;
/* 追加 */
transform: translate(-50%, -50%);
}
data:image/s3,"s3://crabby-images/0e29d/0e29d9617e0f341eba4527ea80d21bb21c5b6c45" alt="中央寄せ②の表示結果"
data:image/s3,"s3://crabby-images/0e29d/0e29d9617e0f341eba4527ea80d21bb21c5b6c45" alt="中央寄せ②の表示結果"
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
data:image/s3,"s3://crabby-images/ce388/ce38858c30ce8e7927ab1740ac8fd47ec88f2e60" alt=""
綺麗に子要素が中央に配置されましたね!