关于移动某一元素位置而不影响其他元素位置的解决方案
情景:当有几个元素上下排放在一起,你想调动其中的元素。例如下面有三个盒子你想使中间的盒子移动至第一个盒子右边。如果使用margin可能会比较麻烦,使用浮动可能会更麻烦,会产生更多的问题。那我们该怎么办呢?
这时候我们就要使用定位了
1.定位
定位(position)
- 定位是一种更加高级布局手段
- 通过定位可以将元素摆放到页面的任意位置
- 使用position属性来设置定位
可选值:
static 默认值,元素是静止的没有开启定位
relative 开启元素的相对定位
absolute 开启元素的绝对定位
fixed 开启元素的固定定位
sticky 开启元素的粘滞定位(用的不太多)
-相对定位:
-当元素的position属性值设置为relative时则开启了元素的相对定位
-相对定位的特点:
1.元素开启相对定位以后,如果不设置偏移量元素不会发生任何的变化
2.相对定位是参照于元素在文档流中的位置进行定位的 3.相对定位会提升元素的层级
4.相对定位不会使元素脱离文档流(如果层级不一样会使元素覆盖(如果元素在同一位置))
5.相对定位不会改变的性质块还是块,行内还是行内
-偏移量(offset)
-当元素开启了定位以后,可以用通过偏移量来设置元素的位置
top
-定位元素和定位位置上边的距离
bottom
-定位元素和定位位置下边的距离
-定位元素垂直方向的位置由top和bottom俩个属性来控制
通常情况下我们只会使用其中一
- top值越大,定位元素越向下移动
-bottom值越大,定位元素越向上移动
left
-定位元素和定位位置的左侧距离
right
-定位元素和定位位置的右侧距离
-定位元素水平方向的位置由left和right俩个属性控制
通常情况下只会使用一个
-left越大元素越靠右
-right越大元素越靠左
所以我们就能这样解决
position: relative;
left: 200px;