zoukankan      html  css  js  c++  java
  • 小谈CSS定位

    定义和用法

    position 属性规定元素的定位类型。

    说明

    这个属性定义建立元素布局所用的定位机制。任何元素都可以定位,不过绝对或固定元素会生成一个块级框,而不论该元素本身是什么类型。相对定位元素会相对于它在正常流中的默认位置偏移。

    描述
    absolute

    生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位。

    元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。

    fixed

    生成绝对定位的元素,相对于浏览器窗口进行定位。

    元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。

    relative

    生成相对定位的元素,相对于其正常位置进行定位。

    因此,"left:20" 会向元素的 LEFT 位置添加 20 像素。

    static 默认值。没有定位,元素出现在正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)。
    inherit 规定应该从父元素继承 position 属性的值。

    以上内容摘自w3c    http://www.w3school.com.cn/css/pr_class_position.asp

    自己的理解:

    一个元素在默认情况下是没有定位的,即所说的static属性,

    div1
    div2

    正常情况下div1 和div2都是默认定位,所以他们在属于文档流,也有说是标准流的,此时div1和div2是占空间的,div2之所以在div1的下面,就是因为div1 属于标准流,有自己的空间,其他元素无法占据其位置,只能挨着排放。

    此时改变div1的position属性为absolute,效果如下

    div1
    div2

    从上边的例子可以清楚的看到div2 占据了div1的位置,并没有在div1的下面排放,这是为什么呢?

    当position:absolute 时,此时div1 已经不再属于文档流(脱离了文档流),也就是说div1 不占据任何空间,好比div1 浮起来了,导致div2占去它的空间。

    此时改变div1的position属性为relative,效果如下

    div1
    div1 position: relative
    div2

    从上边的例子可以清楚的看到div2并没有 占据了div1的位置,而是在div1的下面排放,这是为什么呢?

    当position:relative 时,表示div1 此时是相对定位,相对谁呢?相对自己,就是上图的红色边框div相对自己以前的位置(红色虚线框)进行定位,此时div1属于文档流,是占据空间的,还是虚线框所占的空间。所有div2无法上移。

    此时改变div1的position属性为absolute,效果如下

    div1 position: fixed
    div2

    当positon:fixed 时 div1此时相对浏览器惊醒定位,同样也脱硫了文档流,不占据任何空间,div2 上移 占据div1 的位置。表现为 无论怎么拖动滚动条,div1位置相对浏览器始终不变。

    好了,到此打住,放张美女提提神

  • 相关阅读:
    SpringBoot项目中,表单的验证操作
    微信点餐系统(十)-卖家端通用功能和上下架
    IDEA中Springboot静态文件加载(热部署)
    微信点餐系统(九)-卖家端订单
    微信点餐系统(八)-微信支付与退款
    MyBatis的生命周期
    关于flexjson将json转为javabean的使用
    Spring MVC中前端控制器拦截问题
    springmvc实现文件上传
    springmvc拦截器实现用户登录权限验证
  • 原文地址:https://www.cnblogs.com/zjBoy/p/3393436.html
Copyright © 2011-2022 走看看