CSS position 属性用于指定一个元素在文档中的定位方式。 top , right , bottom 和 left 属性则决定了该元素的最终位置。
所有html元素初始 position 都是默认 static ,此时 top , left , right , bottom 和 z-index 属性无效。
相对于 static ,此时 top , left , right , bottom 和 z-index 属性有效。但 position:relative 对 table-*-group , table-row , table-column , table-cell , table-caption 元素无效。
元素会被移出正常文档流,并不为元素预留空间,通过指定元素相对于最近的 非 static 定位祖先元素的偏移,来确定元素位置。绝对定位的元素可以设置外边距( margins ),且不会与其他边距合并。
元素会被移出正常文档流,并不为元素预留空间,而是通过指定元素相对于屏幕视口( viewport )的位置来指定元素位置。元素的位置在屏幕滚动时不会改变。打印时,元素会出现在的每页的固定位置。fixed 属性会创建新的层叠上下文。当元素祖先的 transform , perspective 或 filter 属性非 none 时,容器由视口改为该祖先。
元素根据正常文档流进行定位,然后相对它的 最近滚动祖先 和 containing block (最近块级祖先),包括 table-related 元素,基于 top , right , bottom , 和 left 的值进行偏移。偏移值不会影响任何其他元素的位置。
css常用的定位方式有五种:1、static定位(普通流定位) -------------- 默认定位
2、float定位(浮动定位) 例:float:left
有两个取值:left(左浮动)和right(右浮动)。浮动元素会在没有浮动元素的上方,效果上看是遮挡住了没有浮动的元素,有float样式规则的元素是脱离文档流的,它的父元素的高度并不能有它撑开。
如果父元素的宽度太窄,那么其他浮动元素会向下移动,直到有足够的空间(左图所示);如果浮动元素的高度不同,那么其他浮动元素向下移动时,就有可能会出现卡住的情况(下图所示)
注意:浮动元素的外边缘不会超过父元素的内边缘;浮动元素不会上下浮动;浮动元素不会互相重叠,会像行内块元素一样排列。
如果想要既设置浮动,又使父元素的高度被浮动元素撑开,即清除子元素浮动对父元素带来的高度的影响,有四种方法可以实现:
假设HTML代码部分为:
<div class="parent">这是父元素
<div style="float:left">这是子元素</div>
</div>
1) 为父元素设置固定高度 -------------缺点:不知道具体高度没办法设置
CSS代码部分:
.parent{
//...
height:xxx//某个固定值
}
2) 在父元素内,在浮动元素的下方多写一行代码:<div style="clear:both"></div>------------- 缺点:增加代码冗余
HTML代码部分:
<div class="parent">这是父元素
<div style="float:left">这是子元素</div>
<div style="clear:both"></div>
</div>
3) 为父元素设置css规则:overflow:hidden ------------- 缺点:有时候不希望超出部分隐藏
.parent{
// ...
overflow:hidden //某个固定值
}
4) 内容生成 ------------- 最优的方法,推荐
CSS代码部分:
.parent:after{
content:''
display:'block'
clear:both
}
3、relative定位(相对定位) position:relative
相对本元素的左上角进行定位,top,left,bottom,right都可以有值。虽然经过定位后,位置可能会移动,但是本元素并没有脱离文档流,还占有原来的页面空间。可以设置z-index。使本元素相对于文档流中的元素,或者脱离文档流但是z-index的值比本元素的值要小的元素更加靠近用户的视线。
相对定位最大的作用是为了实现某个元素相对于本元素的左上角绝对定位,本元素需要设置position为relative。
4、absolute定位(绝对定位) position:absolute
相对于祖代中有relative(相对定位)并且离本元素层级关系上是最近的元素的左上角进行定位,如果在祖代元素中没有有relative定位的,就默认相对于body进行定位。
5、fixed定位(固定定位)position:fixed
相对于窗口的位置,而且不受其他网页内元素影响,永远处于浏览器窗口的相对位置。
绝对定位是脱离文档流的,与浮动定位是一样的效果,会压在非定位元素的上方。可以设置z-index属性。
注意:当同时有浮动元素和绝对定位元素出现并且浮动元素没有设置z-index,浮动元素是压在绝对定位元素上的,即离用户的视线更近。
4 种不同类型的定位。static:默认值,没有定位,元素出现在正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)。
relative:生成相对定位的元素,相对于其正常位置进行定位。元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。
fixed:元素框的表现类似于将 position 设置为 absolute,不过其包含块是视窗本身。
absolute:生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位。
元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。