bottom

bottom样式属性定义了定位元素下外边距边界与其包含块下边界之间的偏移,非定位元素设置此属性无效。

bottom的效果取决于元素的position属性:

  • position设置为absolutefixed时,bottom属性指定了定位元素下外边距边界与其包含块下边界之间的偏移。
  • position设置为relative时,bottom属性指定了元素的下边界离开其正常位置的偏移。
  • position设置为sticky时,如果元素在 viewport 里面,bottom属性的效果和 position 为relative等同;如果元素在 viewport 外面,bottom属性的效果和 position 为fixed等同。
  • position设置为static时,bottom属性无效。

topbottom同时指定时,并且 height没有被指定或者指定为auto100%的时候,topbottom都会生效,在其他情况下,如果 height被限制,则top属性会优先设置,bottom属性则会被忽略。

初始值auto
适用元素positioned elements
是否是继承属性
Percentagesrefer to the height of the containing block
计算值if specified as a length, the corresponding absolute length; if specified as a percentage, the specified value; otherwise, auto
Animation typea length, percentage or calc();

语法

/* <length> values */
bottom: 3px;
bottom: 2.4em;

/* <percentage>s of the height of the containing block */
bottom: 10%;

/* Keyword value */
bottom: auto;

/* Global values */
bottom: inherit;
bottom: initial;
bottom: unset;

  • 对于绝对定位的元素,元素下外边距边界与其包含块下边界之间的偏移。
  • 对于相对定位定位的元素,元素的下边界离开其正常位置的偏移。
  • <length>
    • : 一个负值、空值或正值,代表了:
  • <percentage>
  • auto
    • : 规定:
      • 对于绝对定位元素,元素将忽略此属性而以top属性为准,如果此时设置height: auto,将基于内容需要的高度设置宽度;如果top也为auto的话,元素的垂直位置就是它假如作为静态 (即 static) 元素时该在的位置。
      • 对于相对定位元素,元素相对正常位置的偏移量将基于top属性;如果top也为auto的话,元素将不会有偏移。
  • inherit
    • : 指代有明确计算结果的父级元素的值,(需要注意的是,父级元素并不一定是包裹该子元素的块级元素)。该值会根据父级元素的具体情况被处理为<length>, <percentage>或者auto

Formal syntax

bottom = 
auto |
<length-percentage>

<length-percentage> =
<length> |
<percentage>

示例

下面的例子分别展示了bottom属性在positionabsolutefixed的不同行为。

HTML

html
<p>
  This<br />is<br />some<br />tall,<br />tall,<br />tall,<br />tall,<br />tall<br />content.
</p>
<div class="fixed"><p>Fixed</p></div>
<div class="absolute"><p>Absolute</p></div>

CSS

css
p {
  font-size: 30px;
  line-height: 2em;
}

div {
  width: 48%;
  text-align: center;
  background: rgba(55, 55, 55, 0.2);
  border: 1px solid blue;
}

.absolute {
  position: absolute;
  bottom: 0;
  left: 0;
}

.fixed {
  position: fixed;
  bottom: 0;
  right: 0;
}

结果

规范

Specification
CSS Positioned Layout Module Level 3
# insets

浏览器兼容性

BCD tables only load in the browser