【CSS】position: relative;とposition: absolute;子要素にもなる親要素にはどっちをつけるの
data:image/s3,"s3://crabby-images/116c8/116c8becc752e04859de93a759eb8a41030ac93b" alt=""
data:image/s3,"s3://crabby-images/033c8/033c883ba86f7d2724f77c4f4377b9f81f316d2d" alt=""
画像に画像を重ねて表示させたい時などに、親要素にはposition: relative;、子要素にはposition: absolute;を指定すれば親要素の上で表示させたい場所に配置させることができますよね。
data:image/s3,"s3://crabby-images/033c8/033c883ba86f7d2724f77c4f4377b9f81f316d2d" alt=""
ところが、下のように用意したものを
data:image/s3,"s3://crabby-images/020b4/020b4c9d92c97a4715ac3967586cdfa4de12c213" alt=""
data:image/s3,"s3://crabby-images/033c8/033c883ba86f7d2724f77c4f4377b9f81f316d2d" alt=""
このようにするにはオレンジの「parent」に
position: relative;とabsoluteのどちらを指定すればいいのか迷ってしましました。
data:image/s3,"s3://crabby-images/7d24b/7d24b9cb1c9c0886f50a477a06c2374c7925edc4" alt=""
子要素にもなる親要素
まず「parent」は「child」の親要素なので
このように指定しました。
.parent {
position: relative;
}
.child {
position: absolute;
top: 40px;
left: 3px;
}
data:image/s3,"s3://crabby-images/5eb39/5eb39fcb502cad83d150cf537b219791db4050a2" alt=""
このようにうまく配置できました。
「parent」を「bg」の左上に配置する
親に「 position: relative;」ということで「parent」の親になる「bg」に「position: relative;」を指定してみます。
.bg {
position: relative;
}
.parent {
position: relative;
top: 10px;
left: 10px;
}
.child {
position: absolute;
top: 40px;
left: 3px;
}
data:image/s3,"s3://crabby-images/0d1f4/0d1f48abe7b16cefb7108d9d696b4f506ca774d6" alt=""
指定前
data:image/s3,"s3://crabby-images/2d26b/2d26bb5b447e34f164943150f36485fe29e12964" alt=""
top:100px;
left:100px;
「bg」には重ならず離れてしましました。
やりたいことと違いますね。
親にもposition: absolute;
今度は「parent」にposition: absolute;を指定します。
.bg {
position: relative;
}
.parent {
position: absolute;
top: 10px;
left:10px;
}
.child {
position: absolute;
top: 40px;
left: 3px;
}
data:image/s3,"s3://crabby-images/abd98/abd9830047b734984f74c2e75d7e0ac080851d95" alt=""
するとこのように配置したい場所に表示することができました。
子要素の「child」も離れずついてきてくれています。
まとめ
祖先要素には「position: relative;」
親要素には「position: absolute;」
子要素には「 position: absolute;」
で配置させることができました。
同じカテゴリの記事一覧へ