New(?) way to center elements verticaly.
Maybe new, maybe not, I don't know but I haven't seen it anywhere.
This technique is based on two inline-block elements with vertical-align set to middle. First one have set 100% height and second one is where we put content.
HTML:
<i class="inliner"></i>
<div>Sample content</div>
CSS:
.inliner {
height: 100%;
}
.inliner,
.inliner + * {
display: inline-block;
vertical-align: middle;
}
You can play with it here: http://jsbin.com/oxuyop/919/edit
Written by Kasper Mikiewicz
Related protips
16 Responses
data:image/s3,"s3://crabby-images/1a0ec/1a0ec714d680d85e0fcb940a40f439e5759264b7" alt=""
Great tip! Doesn't seem to work in IE7 tho..
data:image/s3,"s3://crabby-images/51bbe/51bbe399b0c1a9447bd36df7a7e6906a9c6efce5" alt=""
nice once :D
data:image/s3,"s3://crabby-images/ee620/ee620f44d1c5014d7fa0307eede1c0ba4b690b95" alt=""
@emilnordh I was thinking the same thing. Thanks for trying out.
data:image/s3,"s3://crabby-images/3b6a5/3b6a5644db1110e178ec0b226d7352a818c71356" alt=""
@emilnordh What about IE8?
data:image/s3,"s3://crabby-images/41b79/41b7966bab01c8ca859046afa6bc3d98228424ae" alt=""
And given we're not supporting IE7 (don't know about IE8, either, though, but should work)... here's the obligatory no-extra-markup version: http://jsbin.com/oxuyop/102/edit
data:image/s3,"s3://crabby-images/09294/0929494e6712a3423518a849db7980e94735865b" alt=""
@nathansmonk It works in IE8+ and any browser that support display: inline-block;
@passcod looks good tought you will be able to center only one element in page. With mine code you can center anything ;)
data:image/s3,"s3://crabby-images/41b79/41b7966bab01c8ca859046afa6bc3d98228424ae" alt=""
@idered No no no... you can center anything too. I'm just using the body
element as a container. Replace body:before
with parentelement:before
and everything still just works (see: http://jsbin.com/oxuyop/144/edit). After all, it uses the exact same technique... just without extra markup.
data:image/s3,"s3://crabby-images/1a0ec/1a0ec714d680d85e0fcb940a40f439e5759264b7" alt=""
@passcod :before and :after isn't supported i IE7 either. @idered I think IE7 supports inline-block on elements wich are usually used as inline?
data:image/s3,"s3://crabby-images/09294/0929494e6712a3423518a849db7980e94735865b" alt=""
@emilnordh Nope, it doesn't support it at all. Usualy *display: inline; is used as fallback for IE7 but in this case it doesn't work.
data:image/s3,"s3://crabby-images/6558d/6558dc02c628ceed969b6fada8dda264c07e5aaa" alt=""
I first ran across this tip at http://css-tricks.com/centering-in-the-unknown/ , and he references http://gtwebdev.com/workshop/vcenter/vcenter-inline-css.php . Doesn't matter if others already have it though, it's a great tip!
data:image/s3,"s3://crabby-images/8f4f9/8f4f9fbb6cd26b0f34a5c25491739261fc07788b" alt=""
@emilnordh IE7 = .87% users. Screw them. :)
Btw great tip. Thanks so much.
data:image/s3,"s3://crabby-images/2e8b7/2e8b732b3d1d73af34f84624d6b0ac4cdf6ef506" alt=""
@nathansmonk IE8 don't work
data:image/s3,"s3://crabby-images/bbd0d/bbd0da160b1c46cbf3ebcfc61d5dc930a91c49b7" alt=""
You can do this with a single element using :before pseudo-element: http://bl.ocks.org/2867324, it avoids the extra DOM element.
data:image/s3,"s3://crabby-images/07eba/07ebae3c82f912972a8d27893c941f5eec24b8e1" alt=""
I already tried this without using * selector
https://coderwall.com/p/bjovyw?i=5&p=1&q=&t%5B%5D=%21%21mine&t%5B%5D=%21%21bookmarks
With IE7 you may have to force haslayout. This is generally the way I handle inline-block:
Display:inline-block;
Zoom:1;
*display:inline;
thank you for example