定位=定位模式+边偏移css
定位模式:用于指定一个元素在文档中的定位方式,经过position属性设置。浏览器
属性值 | 说明 |
---|---|
static | 静态定位 |
relative | 相对定位 |
absolute | 绝对定位 |
fixed | 固定定位 |
边偏移:决定了该元素的最终位置。布局
边偏移属性 | 示例 | 描述 |
---|---|---|
top | top: 10px | 顶端偏移量,定义元素相对于其父元素上边线的距离 |
bottom | bottom: 10px | 底部偏移量,定义元素相对于其父元素下边线的距离 |
left | left: 10px | 左侧偏移量,定义元素相对于其父元素左边线的距离 |
right | right: 10px | 右侧偏移量,定义元素相对于其父元素右边线的距离 |
元素的默认定位方式,无定位的意思。3d
选择器 { position: static; }
元素在移动位置的时候,是相对于它原来的位置来讲的。code
选择器 { position: relative; }
特色:blog
元素在移动位置的时候,是相对于它父级元素来讲的。图片
选择器 { position: absolute; }
特色:文档
绝对定位小技巧:绝对定位的盒子居中it
加了绝对定位的盒子不能经过margin: 0 auto设置水平居中,解决方案以下。io
元素固定于浏览器可视区的位置,能够在浏览器页面滚动时元素的位置不会改变。
选择器 { position: fixed; }
特色:
固定定位小技巧:固定在版心右侧位置
粘性定位能够被认为是相对定位和固定定位的混合。
选择器 { position: sticky; top: 10px; }
特色:
“子绝父相”:子级是绝对定位的话,父级要用相对定位。
相对定位常常用来做为绝对定位的父级。
一句话总结,由于父级须要占有位置,所以是相对定位,子盒子不须要占有位置,则是绝对定位。
注:若父级盒子不须要占有位置,“子绝父绝”也会遇到。
定位模式 | 是否脱标 | 移动位置 | 是否经常使用 |
---|---|---|---|
static 静态 | 否 | 不能使用边偏移 | 不多 |
relative 相对 | 否 | 相对于自身位置移动 | 经常使用 |
absolute 绝对 | 是 | 带有定位的父级盒子 | 经常使用 |
fixed 固定 | 是 | 浏览器可视区 | 经常使用 |
sticky 粘性 | 否 | 浏览器可视区 | 当前阶段少 |
控制盒子的先后次序(z轴)。
选择器 { z-index: 1; }
绝对定位、固定定位也和浮动相似。
浮动元素、绝对定位、固定定位的元素都不会触发外边距合并的问题。
一个完整的网页,是标准流、浮动、定位一块儿完成布局的,每一个都有本身的专门用法。
标准流
可让盒子上下排列或者左右排列,垂直的块级盒子显示就用标准流布局。
浮动
可让多个块级元素一行显示或者左右对齐盒子,多个块级盒子水平显示就用浮动布局。
定位
定位最大的特色就是有层叠的概念,就是可让多个盒子先后叠压来显示。若是元素自由在某个盒子内移动就用定位布局。