首页 > Web开发 > 详细

CSS 定位position,absolute,relative,float,clear

时间:2014-03-28 14:53:26      阅读:523      评论:0      收藏:0      [点我收藏+]
一 概述

CSS 有二种基本的定位机制:文档流、脱离文档流。
除非指定元素定位属性,否则所有元素框都在文档流中定位。也就是说,文档流中的元素位置由元素在 X(HTML) 中的位置决定。

二 CSS定位相关的两属性 position 和 float
(1)position:定位时,使用 left,right,top,bottom 中至少一个值定位。

值:
static:正常文档流布局,默认值。
relative(相对):不脱离文档流,其“相对于”它在文档流中原位置进行垂直水平偏移,所有后序元素原位置不变,但可能覆盖后序元素,但不算层叠,不可通过 z-index 属性定义。
bubuko.com,布布扣

absolute(绝对):脱离文档流,不占据空间,所有后序元素自动前移,绝对定位元素的起点位置相对于最近已定位(只需指定一个position属性)祖先元素(从父元素开始搜索)以外边距后为起点(可存在内边距里,如图:bubuko.com,布布扣,如果元素没有已定位的祖先元素,那么它的位置相对于最初的包含块(body)。可多重层叠通过 z-index 属性定义。 定位后生成一个块级框,而不论原来它在文档流中是何种类型的框。


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

bubuko.com,布布扣

(2)float:浮动的框可以向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止。由于浮动框脱离文档流,所以文档流中的其它元素块框表现得就像浮动框不存在一样。定位时,与margin与padding相关。
bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣

(3)clear 
定义和用法
clear 属性
设置元素的侧面是否允许其他的浮动元素。
说明
clear 属性定义了元素的哪边上不允许出现浮动元素。在 CSS1 和 CSS2 中,这是通过自动为清除元素(即设置了 clear 属性的元素)增加上外边距实现的。
在 CSS2.1 中,会在元素上外边距之上增加清除空间,而外边距本身并不改变。不论哪一种改变,最终结果都一样,如果声明为左边或右边清除,会使元素的上外边框边界刚好在该边上浮动元素的下外边距边界之下。
值  描述
left  在左侧不允许浮动元素。
right  在右侧不允许浮动元素。
both  在左右两侧均不允许浮动元素。
none  默认值。允许浮动元素出现在两侧。

图像的左侧和右侧均不允许出现浮动元素:img{float:left;clear:both;}

bubuko.com,布布扣
bubuko.com,布布扣
bubuko.com,布布扣 

CSS 定位position,absolute,relative,float,clear,布布扣,bubuko.com

CSS 定位position,absolute,relative,float,clear

原文:http://www.cnblogs.com/hanyingme/p/3630283.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!