How can I have a DIV's width behave like it does when float:left
is set, but without setting a float? width:auto
doesn't seem to do it (in chrome).
I am trying to get something like the following to 开发者_开发百科work...
.center
{
margin-left: auto;
margin-right: auto;
width: auto;
}
Solution with inline-block
You could try display: inline-block
and see if that works in your situation. However, you won't be able to center it using margin-left: auto
& margin-right: auto
because that technique requires a width value.
If possible, use display: inline-block
and set text-align: center
on it's container.
<div style="text-align: center">
<div style="display: inline-block;">
This will expand only as far as it needs to
</div>
</div>
Solution using Flexbox + container div
The original answer above was written in 2011, before flexbox was implemented. You can achieve a similar effect
<div style="display: flex; justify-content: center;">
<div>
This will expand only as far as it needs to
</div>
</div>
Solution without container div
There is another way to do this without a parent element.
- Set display to
inline-block
to make the div width fit to its content. - Use
position: relative
andleft: 50%
to position its left edge to 50% of its containing element. - Use
transform: translateX(-50%)
which will "shift" the element to the left by half its own width.
.center {
display: inline-block;
position: relative;
left: 50%;
transform: translateX(-50%);
}
I think this works nowadays:
.center
{
width: fit-content;
margin-left: auto;
margin-right: auto;
}
For those of you who are still coming across this issue, nowadays you can handle this with:
<div>
<div style="display: table; margin: auto">
This will expand only as far as it needs to
</div>
</div>
Here is a new fiddle based on the accepted answer: http://jsfiddle.net/j33qL8pa/1/
<div>
s are block elements. They take the full width of their containers. Period. Just like <body>
or <html>
Your rule above is essentially doing this:
div { width:100%; margin:0 auto; }
as 100% is its auto value.
inline-block
would work, but it won't work exactly like a true inline-block
element.
Basically...you can't do it without setting a width, positioning it.
If you go the inline-block route, give this a read...you may end up fighting some unexpected battles with your CSS expectations.
http://www.brunildo.org/test/InlineBlockLayout.html (link found near the bottom of the following msdn page) http://msdn.microsoft.com/en-us/library/ms530751%28v=vs.85%29.aspx
精彩评论