HTML&CSS

css-03

2020-09-22  本文已影响0人  Grandperhaps

1. css布局的三种机制

  1. 普通流标准流
  2. 浮动
  1. 定位

2. 定位模式

语义
static 静态定位
relative 相对定位
absolute 绝对定位
fixed 固定定位

3.静态定位(static)

4. 相对定位(relative)

相对定位是元素相对于它 原来在标准流中的位置 来说的。

04_相对定位案例.png
相对定位的特点:

5. 绝对定位(absolute)

绝对定位是元素以带有定位的父级元素来移动位置

  1. 完全脱标 —— 完全不占位置;

  2. 父元素没有定位,则以浏览器为准定位(Document 文档)。

    05_绝对定位_父级无定位.png
  3. 父元素要有定位

定位口诀 —— 子绝父相
子绝父相 —— 子级绝对定位,父级要用相对定位。

6. 固定定位(fixed)

固定定位绝对定位的一种特殊形式: (认死理型) 如果说绝对定位是一个矩形 那么 固定定位就类似于正方形

  1. 完全脱标 —— 完全不占位置;
  2. 只认浏览器的可视窗口 —— 浏览器可视窗口 + 边偏移属性 来设置元素的位置;
    • 跟父元素没有任何关系;单独使用的
    • 不随滚动条滚动。

7. 绝对定位的盒子居中

注意绝对定位/固定定位的盒子不能通过设置 margin: auto 设置水平居中

在使用绝对定位时要想实现水平居中,可以按照下图的方法:

10_绝对定位水平居中.png
  1. left: 50%;:让盒子的左侧移动到父级元素的水平中心位置
  2. margin-left: -100px;:让盒子向左移动自身宽度的一半

盒子居中定位示意图

11_绝对定位居中示意图.png

8. 堆叠顺序

在使用定位布局时,可能会出现盒子重叠的情况

加了定位的盒子,默认后来者居上, 后面的盒子会压住前面的盒子。

应用 z-index 层叠等级属性可以调整盒子的堆叠顺序。如下图所示:

12_zindex示意图.png
z-index 的特性如下:
  1. 属性值正整数负整数0,默认值是 0,数值越大,盒子越靠上;
  2. 如果属性值相同,则按照书写顺序,后来居上
  3. 数字后面不能加单位

注意z-index 只能应用于相对定位绝对定位固定定位的元素,其他标准流浮动静态定位无效。

9. 定位改变display属性

display 是 显示模式, 可以改变显示模式有以下方式:

所以说, 一个行内的盒子,如果加了浮动固定定位绝对定位,不用转换,就可以给这个盒子直接设置宽度和高度等。
同时注意:

浮动元素、绝对定位(固定定位)元素的都不会触发外边距合并的问题。 (我们以前是用padding border overflow解决的)

也就是说,我们给盒子改为了浮动或者定位,就不会有垂直外边距合并的问题了。

小结

定位模式 是否脱标占有位置 移动位置基准 模式转换(行内块) 使用情况
静态static 不脱标,正常模式 正常模式 不能 几乎不用
相对定位relative 不脱标,占有位置 相对自身位置移动 不能 基本单独使用
绝对定位absolute 完全脱标,不占有位置 相对于定位父级移动位置 要和定位父级元素搭配使用
固定定位fixed 完全脱标,不占有位置 相对于浏览器移动位置 单独使用,不需要父级
上一篇 下一篇

猜你喜欢

热点阅读