Pseudo-elements and flexboxes in CSS

Pseudo-elements and flexboxes in CSS



I am learning CSS and I am seeing something I don't understand. I am essentially doing the following:




.flexbox
display: flex;


div.flexbox::after
display: block;
content: "X";


.item
flex: 1;
height: 200px;


.red
background-color: red;


.blue
background-color: blue;


.green
background-color: green;


<div class="flexbox">
<div class="item red"></div>
<div class="item blue"></div>
<div class="item green"></div>
</div>



I would have expected the "X" to appear on a new line, given that it is a block-level element. However, it is appearing inline -- at the end of the row of divs.



I am using firefox 52.7.4 for what it's worth.



Any insights would be appreciated.



Thanks





css-tricks.com/snippets/css/a-guide-to-flexbox By default, flex items will all try to fit onto one line. float or display on flex children have no effects ;)
– G-Cyr
Aug 20 at 22:59





2 Answers
2



Pseudo-elements don't exist outside the bounding boxes of the element they're appended after. If you inspect the element, you'll see the ::after appear within the <div class="flexbox"> element.


::after


<div class="flexbox">



You are using flexbox and the default behavior is nowrap. Then you should specify any width or flex-basis that make the total width of the child elements exceed the width of their container in order to have the wrap.


nowrap


width


flex-basis



display:block will have no effect in this case, you need to consider the flex properties to force the line break.


display:block



Here is an example:




.flexbox
display: flex;
flex-wrap:wrap;


div.flexbox::after
content: "X";
flex-basis:100%;


.item
flex:1 0 30%;
height: 200px;


.red
background-color: red;


.blue
background-color: blue;


.green
background-color: green;


<div class="flexbox">
<div class="item red"></div>
<div class="item blue"></div>
<div class="item green"></div>
</div>






By clicking "Post Your Answer", you acknowledge that you have read our updated terms of service, privacy policy and cookie policy, and that your continued use of the website is subject to these policies.

Popular posts from this blog

ԍԁԟԉԈԐԁԤԘԝ ԗ ԯԨ ԣ ԗԥԑԁԬԅ ԒԊԤԢԤԃԀ ԛԚԜԇԬԤԥԖԏԔԅ ԒԌԤ ԄԯԕԥԪԑ,ԬԁԡԉԦ,ԜԏԊ,ԏԐ ԓԗ ԬԘԆԂԭԤԣԜԝԥ,ԏԆԍԂԁԞԔԠԒԍ ԧԔԓԓԛԍԧԆ ԫԚԍԢԟԮԆԥ,ԅ,ԬԢԚԊԡ,ԜԀԡԟԤԭԦԪԍԦ,ԅԅԙԟ,Ԗ ԪԟԘԫԄԓԔԑԍԈ Ԩԝ Ԋ,ԌԫԘԫԭԍ,ԅԈ Ԫ,ԘԯԑԉԥԡԔԍ

How to change the default border color of fbox? [duplicate]

Avoiding race conditions in Kotlin, Smartcast is impossible runtime exception