質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

1回答

10671閲覧

疑似要素のbefore、afterはそれを当てたブロック要素に重なってしまうのでしょうか。

tokyodesk

総合スコア56

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2017/09/17 19:56

<html> <head> <meta charset="utf-8"> <title>Heart_Beat_GIFT</title> <link rel="stylesheet" href="./reset.css"> <link rel="stylesheet" href="./base.css"> <link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/jquery.slick/1.6.0/slick.css"> <link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/jquery.slick/1.6.0/slick-theme.css"> <link rel="stylesheet" href="./common.css"> <link rel="stylesheet" href="./top.css"> <link rel="stylesheet" href="./sample.css"> </head> <body> <main> <article class="side_length"> <div class="side_length_limit"> <h1></h1> <ul class="top_gyarally_container"> <li> </li> <li> </li> <!-- <div>abc</div> --> <li> </li> <li> </li> </ul> </div> </article> </main>> </body> </html> コード
li{ list-style: none; } .top_gyarally_container { display: flex; flex-wrap: wrap; justify-content: space-between; padding: 0px 16px 0px 16px; } .top_gyarally_container li{ width: 260px; height: 260px; background-repeat: no-repeat; background-position: 50% 50%; background-size: contain; /* background -color: black; */ background-color: #330033; margin-top: 24px } .top_gyarally_container li:nth-child(1){ background-image: url('https://placehold.jp/150x150.png'); } .top_gyarally_container li:nth-child(2){ background-image: url('https://placehold.jp/150x150.png'); } .top_gyarally_container li:nth-child(2):after{ content: "abc"; display: block; color: red; } コード

上記の背景画像にあてた疑似要素のafterなのですが、私の想定では四角形の真下に表示されるはずでした。。
しかしなぜか背景画像の左上に重なって文字が表示されています。
liにきっちりと幅と高さを持たせているので、普通は勝手に重なったりしないと思ったのですが、これはどういうことなのでしょうか。
疑似要素の仕様で重なるようになっているのでしょうか。
それとなのですが、beforeに変えてもafterと同じ表示結果でした。
これも意味がわからないのですが仕組みを教えていただけないでしょうか。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

liにきっちりと幅と高さを持たせているので、普通は勝手に重なったりしないと思ったのですが、これはどういうことなのでしょうか。

ディベロッパーツールで確認するとわかると思いますが、疑似要素は指定したセレクタや要素に内包されています。
つまり、<li>に対して疑似要素を指定した場合、 ::after<li>の子要素となるので、<li>の高さを指定しようがしまいが重なって表示されることになります。

投稿2017/09/17 23:41

hatena_kf

総合スコア21

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tokyodesk

2017/09/18 02:05

やっと理解できました。 大変ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問