auto在css中属性值有效长度单位
理解前须知:
1.width/height的默认值为auto
2.margin的默认为0
margin属性值可以为百分比3.padding的默认为0
4.left right top bottom默认值为auto
5.border不写属性的情况下默认为0
6.如果border:solid不指定大小单边默认为2.4px,最小可设为为0.8px
元素的水平方向的布局:
元素在其父元素中水平方向的位置由以下几个属性共同决定
一个元素在其父元素中,水平布局必须要满足以下的等式 margin-left+border-left+padding-left+width+
padding-right+border-right+margin-right=其父元素内容区的宽度(必须满足)
0+0+0+200+0+0+0=800
什么是auto?
auto是自适应的意思,auto是很多尺寸值的默认值,也就是由浏览器自动计算。
块级元素中margin、border、padding以及content宽度之和构成父元素width。
使用auto属性后,父元素宽度发生变化,该元素的宽度也会随之变化。
auto的值就是margin、border、padding以及content宽度之和。
但是当该元素被设为浮动时,该元素的width就变成了内容的宽度了,由内容撑开,也就是所谓的有了包裹性。
overflowlposition:absolute|float;left/right都可以产生包裹性,替换元素也同样具有包裹性。
*|position:relavtivel相对定位 占原来的位置,不能实现模式的转化,即不具有包裹性。
所以在具有包裹性的元素上不可以利用width:auto;来让元素宽度自适应浏览器宽。
有时设置margin:0 auto;不起作用?
maigin: 0 auto; 指元素的上下边距为0,左右边距根据于父元素(body)宽度自适应,即左右水平居中。
如果该设置不起作用大致下面两和原因。
(1)没有为p设置宽度,如果p么有宽度,就无法参考父元素的宽度来进行自身的auto。
(2)p具有包裹性,即脱离标准流,就好比父对象所在的标准流比喻成地表,那包裹性元素就已经上天了,没有了可供参考的父元素宽度进行auto。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论