css之position与文档流

html-css018

css之position与文档流,第1张

     Css的定位机制分为普通流(文档流)、浮动(float)、定位(position)其中普通流就是文档流,在Html中的写法是从上到下,从左到右的排版布局,其中块级元素独占一行,而内联元素不独占一行。对于文档流来说它的默认position是static就是没有定位。

      position规定元素的定位类型,任何元素都可以定位,不过绝对或固定元素会生成一个块级框,而不管该元素本身是个什么类型,相对元素会相对与它的正常流的默认位置作出偏移。具体:static,position的默认值,表示没有定位,忽略top,left,bottom,right和z-index的影响;absolute,生成绝对定位元素,相对于static定位之外的第一个父元素进行定位,元素位置通过left,top,bottom,right设置;fixed,生成绝对定位元素,相对于浏览器窗口进行定位,通过left,top,bottom,right设置;relative,生成相对定位元素,相对于其正常文档流中的位置进行定位,通过left,top,botton,right设置(注意相对正常位置);inherit规定应该从父元素处继承position属性。

       浮动模型是一种可视化格式模型,浮动的框可以左右移动,直到它的外边缘碰到包含框或者另一个浮动元素的边框,如果包含的框中没有足够的宽度容纳浮动元素那么多余的就会下移。浮动元素不在文档的普通流中,就好比浮动元素在文档流中不存在似的。

       从上面我们知道,被设置了absolute的元素或者float的元素都会脱离文档流,虽然正常的显示还在,但是它其实不占文档流中的空间位置。在float脱离文档流的时候虽然其他盒子无视他,但盒子中的文本围绕它,而absolute脱离文档流会造成其他盒子和盒子的文本都会无视他。

通过浮动可以使其父元素向左侧或者右侧移动

(1)脱离文档流

(2)设置以后会向父元素的左侧或者右侧移动

(3)浮动的元素默认不会从父元素中移出

(4)浮动元素向左向右移动的时候,不会超过他前面的浮动元素

(5)如果浮动元素的上面是一个浮动元素,就不会上移

(6)浮动元素不会超过前面的元素,最都就是一样高

您好!CSS中能够是元素脱离文档流的操作有如下:

1、float

2、position:absolute绝对定位

3、position:fixed固定定位 //IE6不兼容

position:relative 相对定位不会脱离文档流,相对定位具有一下特点:

1、不影响元素本身的特性;

2、不使元素脱离文档流;

3、如果没有定位偏移量,对元素本身没有任何

希望我的回答能够帮助您!

网站课堂团队为您服务!