CSS布局模型
CSS包含3种基本的布局模型,用英文概括为:Flow、Layer 和 Float。
在网页中,元素有三种布局模型:
1、流动模型(Flow)
2、浮动模型 (Float)
3、层模型(Layer)
流动(Flow)是默认的网页布局模式。也就是说网页在默认状态下的 HTML 网页元素都是根据流动模型来分布网页内容的。
流动布局(网页默认方式)模型具有2个比较典型的特征:
第一点,块状元素都会在所处的包含元素内自上而下按顺序垂直延伸分布,因为在默认状态下,块状元素的宽度都为100%。实际上,块状元素都会以行的形式占据位置。如右侧代码编辑器中三个块状元素标签(div,h1,p)宽度显示为100%。
第二点,在流动模型下,内联元素都会在所处的包含元素内从左到右水平分布显示。(内联元素可不像块状元素这么霸道独占一行)
float为左对齐,右对齐,(注意要想让两个div框一行显示,要保证浮动距离小于容器的宽度,容器的宽度随时变化的,否则放不下的移到下一行)
层模型有三种形式:(层模型显示更精确的位置)
1、绝对定位(position: absolute)
2、相对定位(position: relative)
3、固定定位(position: fixed)
1 <!DOCTYPE HTML> 2 <html> 3 <head> 4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 5 <title>absolute样式</title> 6 <style type="text/css"> 7 div{ 8 width:200px; 9 height:200px; 10 border:2px red solid; 11 position:absolute; 12 right:100px; 13 top:20px; 14 15 16 } 17 </style> 18 </head> 19 <body> 20 <div id="div1"></div> 21 </body> 22 </html>
fixed:表示固定定位,与absolute定位类型类似,但它的相对移动的坐标是视图(屏幕内的网页窗口)本身。由于视图本身是固定的,它不会随浏览器窗口的滚动条滚动而变化,
absolute:绝对定位{需要设置position:absolutc(表示绝对定位),这条语句的作用将元素从文档流中拖出来,然后使用”left right top bottom属性相对于其最近的一个具有定位属性的父包含进行绝对定位。如果不存在这样的包含块,则相对body元素,即相对于浏览器窗口。
relative:相对定位{ 如果想为元素设置层模型中的相对定位,需要设置position:relative(表示相对定位),他通过left right top bottom 属性确定元素在正常文档流中的偏移位置。相对定位完成的过程是首先按static(float)方式生成一个元素(并且元素像层一样浮动了起来),然后相对于以前的位置移动,移动的方向和幅度有left right top bottom 属性确定,偏移前的位置保留不动。
fixed:固定定位{ 表示固定定位,与absolute定位类型类似,但他的相对移动的坐标视图(屏幕内的网页窗口)本身。由于视图本身是固定的,他不会随浏览器窗口的滚动而变化,除非你在屏幕中移动浏览器窗口的屏幕位置,或改变浏览器窗口的显示大小,因此固定的点位的元素会始终定位于浏览器的某个窗口内视图的某个位置,不会受某文档流影响。
relative和absolute混用:
1标签相对于2标签,则2标签设置为relative样式,1标签设置为absolute样式,并且在1标签中改变相对于2标签的距离
1 <!DOCTYPE HTML> 2 <html> 3 <head> 4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 5 <title>相对参照元素进行定位</title> 6 <style type="text/css"> 7 div{border:2px red solid;} 8 #box1{ 9 width:200px; 10 height:200px; 11 position:relative; 12 13 } 14 #box2{ 15 position:absolute; 16 top:20px; 17 left:30px; 18 19 } 20 /*下面是任务部分*/ 21 #box3{ 22 width:200px; 23 height:200px; 24 position:relative; 25 } 26 #box4{ 27 width:99%; 28 position:absolute; 29 bottom:0; 32 } 33 </style> 34 </head> 35 36 <body> 37 <div id="box1"> 38 <div id="box2">相对参照元素进行定位</div> 39 </div> 40 41 <h1>下面是任务部分</h1> 42 <div id="box3"> 43 <img src="http://img.mukewang.com/541a7d8a00018cf102000200.jpg"> 44 <div id="box4">当我还是三年级的学生时是一个害羞的小女生。</div> 45 </div> 46 </body> 47 </html>