总结CSS的position定位属性在使用的一些重点

  • 来源: 脚本之家   2016-06-14/17:58
  • 关于CSS定位,有人很多时候都是随便用用,符合自己的要求就行。但是CSS中的position等属性确实有很多需要认真考究的地方。

    1.position:static

    static属性是position的默认值,也就是说,当一个元素没有为其设定position属性时,它的默认值就是static。

    2.position:absolute

    这是一个经常会被用到的position属性值。如果为某个元素设定了absolute,则该元素脱离原来的文档流。形象一些说,比如a元素被定义了position:absolute,那么这个元素就不会与这个页面中的其他元素发生位置上的关系,而是凌驾于整个页面之上的漂浮状态。页面中的其他元素的位置变化、大小变化等,都不会影响a元素的位置,相当于一个局外人。

    3.position:relative

    relative是最有用的定义方法。设置了relative属性表示,该元素相对于自己原来位置发生的变化。比如,我们定义了一个b元素,给它设定如下css样式:

    CSS Code复制内容到剪贴板

    #b{         

    position: relative;         

    width:100px;         

    height:100px;         

    top:100px;     

    }    

    该段代码定义的b元素,它的位置为相对于没有定义position属性的位置向下移动100px的距离。relative属性值的定义就是这样的定位模式。

    4.position:fixed

    fixed定位用的不多,但是它非常适用于固定模式的部分制作,比如顶部菜单。定义了fixed属性后,元素的位置不会随着任何行为发生变化。

    5.relative+position

    同时使用这两个定位,是一种很常用的手法,新手也可能会在此处遇见很多麻烦。总体来说,如果一个元素绝对定位后,其参照物是以离自身最近元素是否设置了相对定位,如果有设置将以离自己最近元素定位,如果没有将往其祖先元素寻找相对定位元素,一直找到html为止。比如,下面的代码利用二者的结合实现了一个两列布局;

    CSS Code复制内容到剪贴板

    #div-1 {                  

    position:relative;     

    }                 

    #div-1a {                  

    position:absolute;                  

    top:0;                  

    rightright:0;                  

    width:200px;     

    }                 

    #div-1b {                  

    position:absolute;                  

    top:0;                  

    left:0;                  

    width:200px;      

    }    

    内部的两个子div会根据其外部定位为relative的元素为参照进行绝对定位。

    6.clear:both清除浮动

    有的时候定位会出现塌陷现象,即子元素在父元素中,但是父元素的大小不会随着子元素的大小而被“”撑开“,导致了父元素的塌陷效果。这种bug的出现是由于子元素设定了 float属性,导致父元素的坍塌。要想解决这种bug,需要为父元素设定清除浮动。示例代码如下:

    CSS Code复制内容到剪贴板

    #div-1a {                  

    float:left;                  

    width:190px;      

    }                 

    #div-1b {                  

    float:left;                  

    width:190px;      

    }                 

    #div-1c {                  

    clear:both;      

    }    


    评论 {{userinfo.comments}}

    {{money}}

    {{question.question}}

    A {{question.A}}
    B {{question.B}}
    C {{question.C}}
    D {{question.D}}
    提交

    驱动号 更多