I made box and I set line-height, the text is automatically vertically center. Is there a way or any kind of trick to set the text on the bottom of the box?
div {
width: 100px;
height: 100px;
background: #eee;
color: #333;
text-align: center;
line-height: 100px;
vertical-align: text-bottom;
}
<div>FoxRox</div>
Setting the height
of the div and the line-height
of the text to the same value, 100px in your case, is a method of vertically centering the text within the div. That's the problem.
Changed line-height
and removed useless vertical-align
=> it's displayed at the bottom now http://dabblet.com/gist/2790000
Enclose the text in a p
tag with display:inline-block
. Set vertical-align
to the p
element.
<div>
<p>FoxRox</p>
</div>
div {
width: 100px;
height: 100px;
background: #eee;
color: #333;
text-align: center;
}
p {
display: inline-block;
vertical-align: -80px;
}
Demo
You could set display to table-cell, try this CSS for example.
width: 100px;
height: 100px;
display: table-cell;
vertical-align: bottom;
Demo: http://jsfiddle.net/Kawwr/
You could check out my answer to https://stackoverflow.com/a/6116514/682480.
Here is the demo for the above answer.
The trick is to use display: table-cell
on the outer container. That way you can use the vertical-align: bottom
and display: inline-block;
on the div.