CSS properties - justify-related

revision:


Content

justify-content property justify-items property justify-self property


justify-content property

top

- aligns the flexible container's items when the items do not use all available space on the main-axis (horizontally).

It defines how the browser distributes space between and around content items along the "main-axis" of a flex container, and the "inline axis" of a grid container.

The alignment is done after the lengths and auto margins are applied, meaning that, if in a Flexbox layout there is at least one flexible element, with flex-grow different from 0, it will have no effect as there won't be any available space.

Tip: Use the align-items property to align the items vertically.

Note: the justify-content property can also be used on a grid container to align grid items in the inline direction. For pages in English, inline direction is left to right and block direction is downward.

CSS syntax : justify-content: flex-start | flex-end | center | space-between | space-around | space-evenly | initial| inherit;

Property values:

flex-start : default value. Items are positioned at the beginning of the container

flex-end : items are positioned at the end of the container

center : items are positioned in the center of the container

space-between : items will have space between them

space-around : items will have space before, between, and after them

space-evenly : items will have equal space around them

initial : sets this property to its default value.

inherit : inherits this property from its parent element.

JavaScript syntax: object.style.justifyContent="space-between"

Syntax examples

/* Positional alignment */
justify-content: center; /* Pack items around the center */
justify-content: start; /* Pack items from the start */
justify-content: end; /* Pack items from the end */
justify-content: flex-start; /* Pack flex items from the start */
justify-content: flex-end; /* Pack flex items from the end */
justify-content: left; /* Pack items from the left */
justify-content: right; /* Pack items from the right */

/* Baseline alignment */
/* justify-content does not take baseline values */

/* Normal alignment */
justify-content: normal;

/* Distributed alignment */
justify-content: space-between; /* Distribute items evenly. The first item is flush with the start, the last is flush with the end */
justify-content: space-around; /* Distribute items evenly. Items have a half-size space on either end */
justify-content: space-evenly; /* Distribute items evenly. Items have equal space around them */
justify-content: stretch; /* Distribute items evenly. Stretch 'auto'-sized items to fit the container */

/* Overflow alignment */
justify-content: safe center;
justify-content: unsafe center;

/* Global values */
justify-content: inherit;
justify-content: initial;
justify-content: revert;
justify-content: unset;

example: justify-content property

The "justify-content: center;" aligns the flex items at the center of the container:

1
2
3
code:
                    <div>
                        <p>The "justify-content: center;" aligns the flex items at the center of the container:</p>
                        <div id="main">
                            <div style="background-color:coral;">1</div>
                            <div style="background-color:lightblue;">2</div>
                            <div style="background-color:pink;">3</div>
                        </div>
                        
                    </div>
                    <style>
                        #main {width: 30vw; height: 10vw; border: 0.2vw solid #c3c3c3; display: flex; justify-content: center;}
                        #main div { width: 5vw; height: 7vw;}
                        
                    </style>
                

example: justify-content property

1
2
3
1
2
3

code:

                    <div>
                        <div id="main_a">
                            <div style="background-color:coral;">1</div>
                            <div style="background-color:lightblue;">2</div>
                            <div style="background-color:pink;">3</div>
                        </div>
                        <div id="main-1">
                            <div style="background-color:coral;">1</div>
                            <div style="background-color:lightblue;">2</div>
                            <div style="background-color:pink;">3</div>
                        </div>
                    </div>    
                    <style>
                        #main_a {margin-left: 1vw;width: 30vw;height: 10vw; border: 0.2vw dotted orange; display: flex; 
                            justify-content: center;}
                        #main-1 {margin-left: 1vw;width: 30vw;height: 10vw; border: 0.2vw dotted orange; display: flex; 
                            justify-content: space-around;}
                        #main_a div {width: 8vw;height: 7vw;}
                        #main-1 div {width: 8vw;height: 7vw;}
                    </style>
                

example: justify-content property

1
2
3
1
2
3

code:

                    <div>
                        <div id="main-2">
                            <div style="background-color:coral;">1</div>
                            <div style="background-color:lightblue;">2</div>
                            <div style="background-color:pink;">3</div>
                        </div>
                        <div id="main-3">
                            <div style="background-color:coral;">1</div>
                            <div style="background-color:lightblue;">2</div>
                            <div style="background-color:pink;">3</div>
                        </div>
                    </div>    
                    <style>
                        #main-2 {margin-left: 1vw;width: 30vw;height: 10vw; border: 0.2vw dotted orange; display: flex; 
                            justify-content: flex-end;}
                        #main-3 {margin-left: 1vw;width: 30vw;height: 10vw; border: 0.2vw dotted orange; display: flex; 
                            justify-content: space-between;}
                        #main-2 div {width: 7vw;height: 7vw;}
                        #main-3 div {width: 6vw;height: 7vw;}
                    </style>
                


justify-items property

top

- is set on the grid container to give child elements (grid items) alignment in the inline direction. For pages in English, inline direction is left to right and block direction is downward.

For this property to have any alignment effect, the grid items need available space around themselves in the inline direction.

Tip: To align grid items in block direction instead of inline direction, use "align-items" property.

.

CSS syntax : justify-items: legacy | normal | stretch | positional alignment | overflow-alignment | baseline alignment | initial | inherit;

Property values:

legacy : default value. Grid items with justify-self value 'auto' only inherits grid container justify-items property value if it starts with 'legacy'. It exists to implement the legacy alignment behavior of HTML's 〈center〉 element and align attribute.

normal : dependent on layout context, but similar to 'stretch' for grid layout

stretch : stretches to fill the grid cell if inline-size (width) is not set.

start : align items at the start in the inline direction

left : align items to the left

center : align items to the center

end : align items to the end in the inline direction

right : align items to the right

overflow-alignment : 'safe' sets alignment of the item to 'start' if the content overflows; 'unsafe' keeps the alignment value regardless of wether or not the item content overflows

baseline alignment : the element is aligned with the baseline of the parent.

initial : sets this property to its default value.

inherit : inherits this property from its parent element.

JavaScript syntax: object.style.justifyItems="center "

example: justify-items property

RED
BLUE
GREEN
RED
code:
                    <div>
                        <div id="container">
                            <div class="red">RED</div>
                            <div class="blue">BLUE</div>  
                        
                            <div class="green">GREEN</div>
                            <div class="red">RED</div>
                        </div>
                        
                    </div>
                    <style>
                        #container {width: 50%; aspect-ratio: 2/1; border: 0.1vw solid black; display: grid; 
                            grid-template-columns: 1fr 1fr; justify-items: end;}
                        #container > div {border: 0.1vw solid black;}
                        .blue {background-color: lightblue; width: 50%;}
                        .red { background-color: coral; width: 40%;}
                        .green {background-color: lightgreen; width: 60%;}
                        
                    </style>
                

justify-self property

top

- aligns a grid item within its grid cell in the inline direction. For pages in English, inline direction is left to right and block direction is downward.

For this property to have any alignment effect, the grid item need available space around itself in the inline direction.

Tip: To align a grid item in block direction instead of inline direction, use "align-self" or "align-items" properties.

CSS syntax : justify-self: auto | normal | stretch | positional alignment | overflow-alignment | baseline alignment | initial | inherit;

Property values:

auto : default value. Grid container justify-self property value is inherited.

normal : dependent on layout context, but similar to 'stretch' for grid layout for grid items when size is not set. If size is set, the property value behaves lik 'start'.

stretch : stretches to fill the grid cell if inline-size (width) is not set.

start : align items at the start in the inline direction

left : align items to the left

center : align items to the center

end : align items to the end in the inline direction

right : align items to the right

overflow-alignment : 'safe' sets alignment of the item to 'start' if the content overflows; 'unsafe' keeps the alignment value regardless of wether or not the item content overflows

baseline alignment : the element is aligned with the baseline of the parent.

initial : sets this property to its default value.

inherit : inherits this property from its parent element.

JavaScript syntax: object.style.justifySelf="right"

example: justify-self property

RED
BLUE
justify-self: right
GREEN
RED
GREEN
RED
GREEN
RED
GREEN
code:
                    <div>
                        <div id="container-A">
                            <div class="red-A">RED</div>
                            <div class="blue-A">BLUE<br>justify-self: right</div>  
                            <div class="green-A">GREEN</div>
                            <div class="red-A">RED</div>
                            <div class="green-A">GREEN</div>
                            <div class="red-A">RED</div>
                            <div class="green-A">GREEN</div>
                            <div class="red-A">RED</div>
                            <div class="green-A">GREEN</div>
                        </div>
                    </div>
                    <style>
                        #container-A {width: 70%; aspect-ratio: 2/1; border: 0.1vw solid black; display: grid; 
                            grid-template-columns: 1fr 1fr 1fr;}
                        #container-A > div {border: 0.1vw solid black;}
                        .blue-A {background-color: lightblue; width: 60%; justify-self: right;}
                        .red-A {background-color: coral; width: 80%;}
                        .green-A {background-color: lightgreen; width: 70%;}
                        
                    </style>