<div id="band"> <div style="background-color: red">John</div> <div style="background-color: green">Paul</div> <div style="background-color: blue">George</div> <div style="background-color: yellow">Ringo</div> </div> <style> body { background-color: slategray; display: flex; justify-content: center; align-items: center; } #band { background-color: white; margin: 0 auto; border-style: solid; border-width: 2px; max-width: 740px; width: 100%; display: flex; /* justify-content: flex-start; */ /* flex-start is the default justify-content */ flex-wrap: wrap; } #band > div { width: 200px; height: 200px; /* center all the names inside each box */ display: flex; justify-content: center; align-items: center; } </style>
Its output is:
data:image/s3,"s3://crabby-images/d4399/d43998b3d547b8027dde6b1d8c295b439fc4d89a" alt=""
If we change the justify-content to center:
display: flex; justify-content: center; flex-wrap: wrap;
Not only the first row's items are centered, the last item will be centered as well, which is not we want:
data:image/s3,"s3://crabby-images/c2497/c24975e774ce048fae191df7e5b9c9cbded8aa98" alt=""
If we want to wrap extra items at leftmost and keep the whole grid of items at the center, we need to use grid instead of flex, and replace flex-wrap: wrap to repeat autofit and minmax. To wit:
display: grid; justify-content: center; grid-template-columns: repeat(auto-fit, minmax(200px, max-content));
The output is correct:
data:image/s3,"s3://crabby-images/fb787/fb787eadcef21d969c87efcbf153e3a6591542f4" alt=""
On the above display grid and grid-template-columns settings, if we change the justify-content to end:
display: grid; justify-content: end; /* flex-end works as well, but we will just be confusing ourselves with that, we are using grid not flex */ grid-template-columns: repeat(auto-fit, minmax(200px, max-content));
The output is:
data:image/s3,"s3://crabby-images/09474/0947483f012eecf6fc9b3cc608c02b0867aeec98" alt=""
To contrast with flex-end of display: flex:
display: flex; justify-content: flex-end; flex-wrap: wrap;
The output is:
data:image/s3,"s3://crabby-images/fc8e8/fc8e8a30eac4698dbeb5e2c4df6501d5e81b5c40" alt=""
Same settings above, but with five items:
data:image/s3,"s3://crabby-images/a83b5/a83b505d84dbbbdd0476eea12aae50ab43fd4659" alt=""
Let's use grid again with justify-content of end:
display: grid; justify-content: end; grid-template-columns: repeat(auto-fit, minmax(200px, max-content));
Its output:
data:image/s3,"s3://crabby-images/2bf05/2bf05fe3ff98cbc6381326acbed1a7aaa27822af" alt=""
This flex's flex-start:
display: flex; justify-content: flex-start; flex-wrap: wrap;
And grid's start:
display: grid; justify-content: start; grid-template-columns: repeat(auto-fit, minmax(200px, max-content));
Have same output:
data:image/s3,"s3://crabby-images/365dd/365dd65ffa9afd69bf153834a6de9714606aa6f3" alt=""
No comments:
Post a Comment