CSS Properties: How to align self auto element inherits its parent container's align-items property, or "stretch" if it has no parent container??
Solution:
HTML Code:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"><!-- Declare character encoding -->
<title>How to align self auto element inherits its parent container's align-items property, or "stretch" if it has no parent container</title><!-- Set the title of the HTML document -->
<style>/* CSS style Starts*/
#xyz {
width: 200px; /* Set width of the container */
height: 250px; /* Set height of the container */
border: 1px solid black; /* Set border of the container */
display: -webkit-flex; /* Safari */ /* Use flexbox layout for Safari */
-webkit-align-items: auto; /* Safari 7.0+ */ /* Set alignment of items to "auto" for Safari */
display: flex; /* Use flexbox layout for other browsers */
align-items: auto; /* Set alignment of items to "auto" for other browsers */
}
#xyz div {
-webkit-flex: 1; /* Safari 6.1+ */ /* Allow the divs to grow and shrink to fill the available space horizontally for Safari */
flex: 1; /* Allow the divs to grow and shrink to fill the available space horizontally for other browsers */
}
div#alignselfautoDiv {
align-self:center; /* Align this specific item vertically to the center */
)
</style>
</head>
<body>
<div id="xyz">
<div style="background-color:#99FF99;">Item1</div><!-- First div item -->
<div style="background-color:#33CCFF;" id="alignselfautoDiv">Item2 with more content.</div><!-- Second div item with alignment specified -->
<div style="background-color:#FF99FF;">Item3</div><!-- Third div item -->
</div>
</body>
</html>
Explanation:
- The HTML document contains a flexible container (div#xyz) with three child div items.
- The align-items property of the container and the child div items is set to "auto", which allows the items to inherit the alignment from their parent container.
- One of the child div items (div#alignselfautoDiv) has its alignment set to center using CSS.
- Since the parent container's align-items property is set to "auto", the child div items inherit this property, resulting in them being aligned according to their parent's alignment property.
Live Demo:
See the Pen align-self-auto-answer by w3resource (@w3resource) on CodePen.
See the solution in the browser
Supported browser
Yes | Yes | Yes | Yes | No |
What is the difficulty level of this exercise?
Test your Programming skills with w3resource's quiz.
It will be nice if you may share this link in any developer community or anywhere else, from where other developers may find this content. Thanks.
https://www.w3resource.com/html-css-exercise/css-properties/align-self-auto-answer.php
- Weekly Trends and Language Statistics
- Weekly Trends and Language Statistics