I am trying to center my tabs content vertically, but when I add the CSS style display:inline-flex, the horizontal text-align disappears.
How can I make both text alignments x and y for each of my tabs?
* { box-sizing: border-box; }
#leftFrame {
background-color: green;
position: absolute;
left: 0;
right: 60%;
top: 0;
bottom: 0;
}
#leftFrame #tabs {
background-color: red;
position: absolute;
top: 0;
left: 0;
right: 0;
height: 25%;
}
#leftFrame #tabs div {
border: 2px solid black;
position: static;
float: left;
width: 50%;
height: 100%;
text-align: center;
display: inline-flex;
align-items: center;
}
first
second
Answer
Approach 1 -
transformtranslateX/translateY:Example Here / Full Screen Example
In supported browsers (most of them), you can use
top: 50%/left: 50%in combination withtranslateX(-50%) translateY(-50%)to dynamically vertically/horizontally center the element.
.container {
position: absolute;
top: 50%;
left: 50%;
-moz-transform: translateX(-50%) translateY(-50%);
-webkit-transform: translateX(-50%) translateY(-50%);
transform: translateX(-50%) translateY(-50%);
}
I'm vertically/horizontally centered!
Approach 2 - Flexbox method:
Example Here / Full Screen Example
In supported browsers, set the
displayof the targeted element toflexand usealign-items: centerfor vertical centering andjustify-content: centerfor horizontal centering. Just don't forget to add vendor prefixes for additional browser support (see example).
html, body, .container {
height: 100%;
}
.container {
display: -webkit-flexbox;
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
-webkit-flex-align: center;
-ms-flex-align: center;
-webkit-align-items: center;
align-items: center;
justify-content: center;
}
I'm vertically/horizontally centered!
Approach 3 -
table-cell/vertical-align: middle:Example Here / Full Screen Example
In some cases, you will need to ensure that the
html/bodyelement's height is set to100%.For vertical alignment, set the parent element's
width/heightto100%and adddisplay: table. Then for the child element, change thedisplaytotable-celland addvertical-align: middle.For horizontal centering, you could either add
text-align: centerto center the text and any otherinlinechildren elements. Alternatively, you could usemargin: 0 auto, assuming the element isblocklevel.
html, body {
height: 100%;
}
.parent {
width: 100%;
height: 100%;
display: table;
text-align: center;
}
.parent > .child {
display: table-cell;
vertical-align: middle;
}
I'm vertically/horizontally centered!
Approach 4 - Absolutely positioned
50%from the top with displacement:Example Here / Full Screen Example
This approach assumes that the text has a known height - in this instance,
18px. Just absolutely position the element50%from the top, relative to the parent element. Use a negativemargin-topvalue that is half of the element's known height, in this case --9px.
html, body, .container {
height: 100%;
}
.container {
position: relative;
text-align: center;
}
.container > p {
position: absolute;
top: 50%;
left: 0;
right: 0;
margin-top: -9px;
}
I'm vertically/horizontally centered!
Approach 5 - The
line-heightmethod (Least flexible - not suggested):In some cases, the parent element will have a fixed height. For vertical centering, all you have to do is set a
line-heightvalue on the child element equal to the fixed height of the parent element.Though this solution will work in some cases, it's worth noting that it won't work when there are multiple lines of text - like this.
.parent {
height: 200px;
width: 400px;
background: lightgray;
text-align: center;
}
.parent > .child {
line-height: 200px;
}
I'm vertically/horizontally centered!
No comments:
Post a Comment