盒子的定位

在这里插入图片描述

三种机制的最后一种:定位

为什么要使用定位?:定位可以把盒子定在某一个位置,自由的漂浮在其他盒子(包括标准流和浮动)的上面,这样可以比标准流和浮动更加灵活的摆放位置。

边偏移

在这里插入图片描述
定位=定位模式+边偏移。
偏移量表示的是元素对于其父元素边线的距离

定位模式

定位的模式有下面这些:

所代表的意思
static静态定位
relative相对定位
absolute绝对定位
fixed固定定位

在这里插入图片描述

  1. 静态定位(static)
    相当于不用定位。基本不会使用。因为写了这句话相当于不用
    在这里插入图片描述

  2. 相对定位(relative)
    相对定位就是相对刚开始的定位,而且移动之后,其原来的位置还是会保存的。
    即是:原来的标准流位置继续占有,后面的盒子仍然以标准流的方式对待它
    在这里插入图片描述

绝对路径(absolute)

正确情况下我们的子盒子是跟父元素的margin变化也会跟着产生位置的变化,但是我们给子元素加上absolute属性后,只会发生跟刚开始本来应该在的位置上的变化。
举例:
1.
在这里插入图片描述
此时效果为:
在这里插入图片描述
说明加上绝对路径是不会跟随父元素的变化而变化的,而是会跟原来的位置的距离来变化。

  1. 但是此时如果我们给父元素也加上absolute属性会如何呢?
    在这里插入图片描述

此时为:
在这里插入图片描述

  1. 将元素依据最近的已经定位(绝对,固定或者相对定位)的父元素(祖先)进行定位
    在这里插入图片描述

  2. 绝对定位的盒子不占有位置
    举个例子:设置一段div标签

<div class="father">
        <div class="damao"></div>
        <div class="ermao"></div>
</div>

在这里插入图片描述
此时效果为:
在这里插入图片描述
此时damao是绝对定位,因为父亲没有绝对定位。damao以浏览器文档为标准移动位置,此时我们看到,蓝色的ermao占据了本该是damao的位置,这说明了绝对定位是不占位置的!

  1. 我们应该使用子绝父相的方式来搭配使用
    在这里插入图片描述
    比如我们看到的这两个轮播图箭头,使用绝对位置可以保证绝对在父元素的左右位置,最重要的是其不占有位置,可以让图片压在它下面。父元素使用相对位置是可以更好的更改页面的布局,更重要的原因是相对位置其占有位置。其他元素还是会将它当作标准流来看待。更好避免不必要的麻烦。
固定定位

固定定位可以算是绝对定位的一种。它具有以下特性:

  1. 完全脱离标准流。完全不占位置
  2. 跟父元素是不是(固定,绝对,相对,静止)定位没有关系;
  3. 不会随滚动条滚动,会一直挂在我们能看见的浏览器上面。
    在这里插入图片描述

在这里插入图片描述

绝对定位的盒子居中方法:

  1. 先让left: 50%,移动到水平左边居中;
  2. 再margin-left: -盒子自身一半的宽度即可实现居中效果了
    在这里插入图片描述
堆层顺序

很多时候有必要的话可以让盒子会发生重叠现象,但是我们很难去让他们谁在最上面,谁次之,谁最后。此时我们通过z-index层叠等级属性即可调整盒子的堆叠顺序。z-index值越大,谁在上面,如果一样,则按照代码顺序
在这里插入图片描述

改变display

改变display可以通过三个方式:inline-block,float,绝对定位和固定定位
在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值