CSS属性中的“auto”值是啥意思。

Posted

技术标签:

【中文标题】CSS属性中的“auto”值是啥意思。【英文标题】:What is the meaning of `auto` value in a CSS property.CSS属性中的“auto”值是什么意思。 【发布时间】:2011-05-27 04:34:03 【问题描述】:

CSS 属性的auto 值是什么意思。当 CSS 属性的值设置为 auto 时会发生什么?

【问题讨论】:

auto 在 CSS 中的行为取决于您分配给的属性。如果您想要更具体的答案,您必须提供一个您感兴趣的属性的示例。 【参考方案1】:

根据元素的内容或上下文,自动调整该属性的值。

例如,带有height: auto 的块级元素会随着包含更多文本而变得更高。再举一个例子,带有margin: 0 auto 的块元素将增加左右边距,直到它沿视口的y 轴居中。

这实际上取决于您赋予值的属性,不同的属性根据内容和上下文表现不同。

【讨论】:

@MarceloBarbosa:不,即使在同时接受两个值的属性中,auto 也并不总是意味着 100%。例如,100% 的宽度会强制 inline-block 元素为其容器宽度的 100%,即使同一行上有其他元素(这些元素被推到下一行)。自动宽度会导致内联块缩小以适应其内容,这当然不是 100%。 如何强制在一行中给出 100% 的块级元素? 'auto' 是所有的默认值吗?每个属性都可以有值'auto'吗? @robsch:不,属性是否具有 auto 作为可能值,更不用说初始值,完全取决于属性。对于大多数属性,自动值完全没有意义。【参考方案2】:

auto 表示自动调整。我使用 auto 的最常见原因是:

margin: 0 auto;

使元素居中。

请注意:如果未声明大小,则它将不起作用。

示例 1:div 不居中,auto 不起作用

<style>
    .cont 
        margin: 0 auto;
    
</style>
<div class="cont"></div> 

示例 2:div 以页面为中心

<style>
    .cont 
        width: 1000px;
        margin: 0 auto;
    
</style>
<div class="cont"></div> 

【讨论】:

【参考方案3】:

这确实取决于您使用的属性。例如,自动设置块宽会扩展其父元素的全部空间。但是自动设置块高只会扩展其内容所需的空间。

<style>
    #outer
        width: 500px;
        height: 500px;
        border: solid 2px black;
    
    #inner
        width: auto;
        height: auto;
        background-color: aqua;
    
</style>
<div id="outer">
<div id="inner">content</div>
</div>

【讨论】:

【参考方案4】:

这取决于。以下是auto 值的一些常见用法。

高度:自动

元素高度取决于其子元素的高度。

.container 
  width: 250px;
  height: auto;
  background: gray;


.item 
  width: 50px;
  background: orange;
<div class="container">
  <div class="item">
    child content
  </div>
</div>

宽度:自动

对于块级元素,宽度是容器宽度减去元素的水平间距(边距+边框+填充)。

.container 
  width: 250px;
  height: 150px;
  background: gray;


.item 
  width: auto;
  margin: 0 10px;
  border-left: 5px solid;
  border-right: 5px solid;
  padding: 0 10px;
  background: orange;
  font-size: 14px;
<div class="container">
  <div class="item">
    calculated content width is 200px
  </div>
</div>

请注意,当容器使用 align 进行伸缩时,行为会有所不同。

.container 
  width: 250px;
  height: 150px;
  display: flex;
  flex-direction: column;
  background: gray;


.item 
  width: auto;
  background: orange;
  /* comment out next line to make width take parent's width */
  align-self: start;
<div class="container">
  <div class="item">
    child
  </div>
</div>

边距:自动

将块级元素水平居中。

.container 
  width: 250px;
  height: 150px;
  background: gray;


.item 
  width: 32px;
  margin: 0 auto;
  background: orange;
<div class="container">
  <div class="item">
    child
  </div>
</div>

将一个元素推到 flex 容器的末尾。

.container 
  width: 300px;
  height: 150px;
  display: flex;
  background: gray;


.item 
  width: 50px;
  height: 25px;
  background: orange;
  border-left: 1px solid;


.item3 
  margin-left: auto;
<div class="container">
  <div class="item">
    child 1
  </div>
  <div class="item">
    child 2
  </div>
  <div class="item item3">
    child 3
  </div>
</div>

【讨论】:

以上是关于CSS属性中的“auto”值是啥意思。的主要内容,如果未能解决你的问题,请参考以下文章

CSS里面的属性margin-right:auto; margin-left:auto;是啥意思??? 还有 line-height是啥意思

保证金自动是啥意思?

js中animate是啥意思

CSS边框半径属性中的“/”是啥意思? [复制]

css 属性值中的 !default 是啥意思?

CSS 声明中的两个点是啥意思?