css中的auto是自动适应的意思,而在css中auto往往都是默认值。正如margin:0auto,意思就是上下边距为0,左右边距为auto,就是自动适应。但是,如果要使用他的话,就必须给标签配上指定的宽度,如下:<divclass="center">居中</div>。
auto怎么样使用
auto是自适应的意思,auto是很多尺寸值的默认值,也就是由浏览器自动计算。
+块级元素中margin、border、padding以及content宽度之和构成父元素width。
使用auto属性后,父元素宽度发生变化,该元素的宽度也会随之变化。
下图中auto的值就是margin、border、padding以及content宽度之和
+但是当该元素被设为浮动时,该元素的width就变成了内容的宽度了,由内容撑开,也就是所谓的有了包裹性。
overflow|position:absolute|float:left/right都可以产生包裹性,替换元素也同样具有包裹性。
*|position:relavtive|相对定位占原来的位置,不能实现模式的转化,即不具有包裹性。
所以在具有包裹性的元素上不可以利用width:auto;来让元素宽度自适应浏览器宽。如下图所示
有时设置margin:0auto;不起作用?
+maigin:0auto;指元素的上下边距为0,左右边距根据于父元素(body)宽度自适应,即左右水平居中。如果该设置不起作用大致下面两种原因。
+(1)没有为DIV设置宽度,如果DIV么有宽度,就无法参考父元素的宽度来进行自身的auto。
+(2)DIV具有包裹性,即脱离标准流,就好比父对象所在的标准流比喻成地表,那包裹性元素就已经上天了。没有了可供参考的父元素宽度进行auto。
总之,auto给大家简单的介绍了一些,希望大家多看看。