zoukankan      html  css  js  c++  java
  • CSS学习总结3:CSS定位

    CSS 定位机制

    CSS 有三种基本的定位机制:普通流、浮动和绝对定位。

    一、普通流
      除非专门指定,否则所有框都在普通流中定位。普通流中元素框的位置由元素在(X)HTML中的位置决定。块级元素从上到下依次排列,框之间的垂直距离由框的垂直margin计算得到。行内元素在一行中水平布置。

    二、定位

    在讲解定位之前先说明相对定位和绝对定位到底是“以何为依据进行定位”相对定位是“相对于”元素在文档中的初始位置;而绝对定位是“相对于”最近的已定位祖先元素(关于祖元素的概念在下面有实例说明),如果不存在祖先元素,那么“相对于”最初的包含块。如果想学会相对定位和绝对定位,那么必须了解这两点的区别。

    2.1、相对定位

    设置为相对定位的元素框会偏移某个距离。元素仍然保持其未定位前的形状,它原本所占的空间仍保留。

    注意,在使用相对定位时,无论是否进行移动,元素仍然占据原来的空间。因此,移动元素会导致它覆盖其它框。

    #box_relative {/*图中的框 2*/
      position: relative;
      left: 30px;
      top: 20px;
    }

    相对定位的工作原理图如下:

     

    2.2、绝对定位

    绝对定位使元素的位置与文档流无关,因此不占据空间。这一点与相对定位不同,相对定位实际上被看作普通流定位模型的一部分,因为元素的位置相对于它在普通流中的位置。

    普通流中其它元素的布局就像绝对定位的元素不存在一样:

    #box_relative {/*图中的框 2*/
      position: absolute;
      left: 30px;
      top: 20px;
    }

    绝对定位的原理图:

    这里用实例说明一下祖元素的概念

    <div>
       <p><span></span></p>
    </div>
    /* div 相对于span来讲,就是祖辈(爷爷) */
    /* span相对于p来讲,就是儿子 */
    /* p相对于span来讲,就是爸爸*/
    
    /* ~.~ */

    2.3、浮动

    CSS浮动部分请参考下一篇博客:经验分享:CSS浮动(float,clear)通俗讲解

    附录:

    CSS position 属性总结:

    所有主流浏览器都支持 position 属性。position属性规定元素的定位类型,影响元素框生成的方式。

    可能的值

    描述
    absolute

    生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位,如果不存在这样的父元素,则依据最初的包含快。根据用户代理的不同,最初的包含块可能是画布或 HTML 元素。

    元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定,也可以通过z-index进行层次分级。

    (元素框从文档流完全删除,并相对于其包含块定位。包含块可能是文档中的另一个元素或者是初始包含块。元素原先在正常文档流中所占的空间会关闭,就好像元素原来不存在一样。元素定位后生成一个块级框,而不论原来它在正常流中生成何种类型的框。)

    fixed

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

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

    (元素框的表现类似于将 position 设置为 absolute,不过其包含块是视窗本身。)

    relative

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

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

    (相对定位实际上被看作普通流定位模型的一部分,因为元素的位置相对于它在普通流中的位置。元素框偏移某个距离。元素仍保持其未定位前的形状,仍保留原本所占的空间。 )

    static

    默认值。没有定位,元素出现在正常的流中(忽略 top, bottom, left, right 或者 z-index 声明,即上述声明无效)。

    (元素框正常生成。块级元素生成一个矩形框,作为文档流的一部分,行内元素则会创建一个或多个行框,置于其父元素中。)

    inherit 规定应该从父元素继承 position 属性的值。(任何版本的IE浏览器均不支持此属性值)

    CSS 定位属性

    CSS 定位属性允许你对元素进行定位。

    属性描述
    position 把元素放置到一个静态的、相对的、绝对的、或固定的位置中。
    top 定义了一个定位元素的上外边距边界与其包含块上边界之间的偏移。
    right 定义了定位元素右外边距边界与其包含块右边界之间的偏移。
    bottom 定义了定位元素下外边距边界与其包含块下边界之间的偏移。
    left 定义了定位元素左外边距边界与其包含块左边界之间的偏移。
    overflow 设置当元素的内容溢出其区域时发生的事情。
    clip 设置元素的形状。元素被剪入这个形状之中,然后显示出来。
    vertical-align 设置元素的垂直对齐方式。
    z-index 设置元素的堆叠顺序。
  • 相关阅读:
    Linux常用命令大全
    Activity的launchMode详细分析
    StringBuilder与StringBuffer的区别(转)
    CSS那些事儿-阅读随笔3(清除浮动)
    CSS那些事儿-阅读随笔2(选择符的组合与优先级/权重)
    CSS那些事儿-阅读随笔1(CSS简介与选择符)
    js快速打印一个五分制(五颗星)的评分情况
    jQgrid问题总结
    Webstorm10.0.4注册码
    浅谈Websocket、Ajax轮询和长连接(long pull)
  • 原文地址:https://www.cnblogs.com/1925yiyi/p/7920119.html
Copyright © 2011-2022 走看看