CSS定位流 相对定位+绝对定位+固定定位

1.相对定位:相对定位就是相对于自己以前在标准流中的位置来移动。

1.1相对定位是不脱离标准流的, 会继续在标准流中占用一份空间

1.2在相对定位中同一个方向上的定位属性只能使用一个

1.3由于相对定位是不脱离标准流的, 所以在相对定位中是区分块级元素/行内元素/行内块级元素

1.4由于相对定位是不脱离标准流的, 并且相对定位的元素会占用标准流中的位置, 所以当给 相对定位的元素设置margin/padding等属性的时会影响到标准流的布局

写法:

img{
            width: 100px;
            height: 50px;
            position: relative;
            top: 20px;/*距离自己原来位置左边20px*/
        }

如果加上margin那么其总体距离等于他们的值之和。

2.绝对定位:绝对定位就是相对于body(父元素无定位属性)来定位。

2.1绝对定位的元素是脱离标准流的

2.2绝对定位的元素是不区分块级元素/行内元素/行内块级元素

绝对定位参考点:

1.规律

默认情况下所有的绝对定位的元素, 无论有没有祖先元素, 都会以body作为参考点

2.如果一个绝对定位的元素有祖先元素, 并且祖先元素也是定位流, 那么这个绝对定位的元素就会以定位流的那个祖先元素作为参考点

2.1只要是这个绝对定位元素的祖先元素都可以

2.2指的定位流是指绝对定位/相对定位/固定定位

2.3定位流中只有静态定位不行

3.如果一个绝对定位的元素有祖先元素, 并且祖先元素也是定位流, 而且祖先元素中有多个元素都是定位流, 那么这个绝对定位的元素会以离它最近的 那个定位流的祖先元素为参考点

由于这一特性,它经常和相对定位进行搭配使用,按照子绝父相原则来

写法:

 .box2{
            width: 200px;
            height: 200px;
            background-color: green;
            position: relative;/*父元素*/
        }
        .box3{
            width: 100px;
            height: 100px;
            background-color: blue;
            position: absolute;/*子元素*/
            left: 0;
            bottom: 0;
          }

如果一个绝对定位的元素是以body作为参考点, 那么其实是以网页首屏的宽度和高度作为参考点, 而不是以整个网页的宽度和高度作为参考点,并且,一个绝对定位的元素会忽略祖先元素的padding

让绝对定位的元素水平居中 只需要设置绝对定位元素的left:50%; 然后再设置绝对定位元素的 margin-left: -元素宽度的一半px;

固定定位:固定定位和前面学习的背景关联方式很像, 背景定位可以让背景图片不随着滚动条的滚动而滚动, 而固定定位可以让某个盒子不随着滚动条的滚动而滚动

注意点:

1.固定定位的元素是脱离标准流的, 不会占用标准流中的空间

2.固定定位和绝对定位一样不区分行内/块级/行内块级

3.IE6不支持固定定位

写法:

  .nav{
            width:100%;
            height: 45px;
            background: url("images/nav.png") no-repeat center top;
            position: fixed;
            top: 0;
            z-index: 1;
        }

1.什么是z-index属性?
默认情况下所有的元素都有一个默认的z-index属性, 取值是0.
z-index属性的作用是专门用于控制定位流元素的覆盖关系的

1.默认情况下定位流的元素会盖住标准流的元素
2.默认情况下定位流的元素后面编写的会盖住前面编写的
3.如果定位流的元素设置了z-index属性, 那么谁的z-index属性比较大, 谁就会显示在上面

注意点:
1.从父现象
1.1如果两个元素的父元素都没有设置z-index属性, 那么谁的z-index属性比较大谁就显示在上面
1.2如果两个元素的父元素设置了z-index属性, 那么子元素的z-index属性就会失效,
也就是说谁的父元素的z-index属性比较大谁就会显示在上面

猜你喜欢

转载自blog.csdn.net/mengxianglong123/article/details/84338510
今日推荐