-
布局模型
是建立在盒模型
基础之上在网页中,不同于CSS 布局样式
或CSS 布局模板
。 - 元素有三种基本布局模型:
1、流动模型(Flow)
2、浮动模型 (Float)
3、层模型(Layer) -
流动模型
:流动(Flow)是默认的网页布局模式
。 - 流动布局模型具有2个比较典型的特征:
1、第一点:块状元素
都会在所处的包含元素内
自上而下按顺序垂直延伸分布,因为在默认状态下,块状元素的宽度都为100%
。实际上,块状元素都会以行的形式
占据位置。
2、第二点:在流动模型下,内联元素
都会在所处的包含元素内从左到右水平分布
显示。(内联元素可不像块状元素这么霸道独占一行)
<!DOCTYPE html>
<html lang="cn">
<head>
<meta charset="UTF-8">
<title>流动模型</title>
<style type="text/css">
#box1{
width:300px;
height:100px;
}
div,h1,p{
border:1px solid red;
}
#b1{
float: left; /*参数设置*/
}
#b2{
float:right;
}
</style>
</head>
<body>
流动模型效果的演示
<br />
<br />
<div id="box2">box2</div>
<!--块状元素,由于没有设置宽度,宽度默认显示为100%-->
<h1>标题</h1>
<!--块状元素,由于没有设置宽度,宽度默认显示为100%-->
<p>文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段。</p>
<!--块状元素,由于没有设置宽度,宽度默认显示为100%-->
<div id="box1">box1</div>
<!--块状元素,由于设置了width:300px,宽度显示为300px-->
<br />
<!-- 在流动模型下,内联元素都会在所处的包含元素内从左到右水平分布显示。-->
<a href="http://www.imooc.com">www.imooc.com</a>
<span>强调</span>
<em>重点</em> <!--显示斜体字-->
<strong>强调</strong>
<hr />
以下是浮动模型的演示效果
<br />
<br />
<div id="b1" >我是左边的div!</div>
<div id="b2" >我是右边的div!</div>
</body>
</html>
测试效果
- 问题1:块状元素这么霸道独占一行,怎么让两个块状元素
并排显示
? - 回答1:任何元素在默认情况下是不能浮动的,但可以
用 CSS 定义为浮动
,如div、p、table、img
等元素都可以被定义为浮动
。 - 主要代码:
div{float:left;}
-
层布局模型
:如何让html元素在网页中精确定位
,就像图像软件PhotoShop中的图层一样可以对每个图层能够精确定位操作。CSS定义了一组定位(position)
属性来支持层布局模型
。 - 层模型有三种形式:
1、绝对定位
(position: absolute)
2、相对定位
(position: relative)
3、固定定位
(position: fixed) - 若想为元素设置
层模型中的绝对定位
,需要设置position:absolute
(表示绝对定位),作用:将元素从文档流
中拖出来,然后使用left
、right
、top
、bottom
属性相对于其最接近的一个具有定位属性的父级元素
进行绝对定位。如果不存在这样的包含块,则相对于body元素
,即相对于浏览器窗口
。
<!DOCTYPE html>
<html lang="cn">
<head>
<meta charset="UTF-8">
<title>层模型</title>
<style type="text/css" >
#div1 {
width:200px;
height: 200px;
border: 2px red solid;
position: absolute; /*绝对定位*/
left: 100px;
bottom: 50px;
}
</style>
</head>
<body>
<div id="div1"></div>
</body>
</html>
绝对定位
- 若想为元素设置
层模型中的相对定位
,需要设置position:relative
(表示相对定位),它通过left
、right
、top
、bottom
属性确定元素在正常文档流
中的偏移位置。相对定位完成的过程是首先按static(float)
方式生成一个元素
(并且元素像层一样浮动了起来),然后相对于以前的位置移动
,移动的方向和幅度由left、right、top、bottom属性确定,偏移前的位置保留不动
。
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>relative样式</title>
<style type="text/css">
#div1{
width:200px;
height:200px;
border:2px red solid;
position:relative;
left:100px;
top:50px;
}
</style>
</head>
<body>
<div id="div1"></div>
<span>这是原来div元素的位置,偏移前的位置保留不动</span>
</body>
</html>
相对定位
测试相对定位
-
从效果图中可以明显的看出,虽然div元素相对于以前的位置产生了偏移,但是div元素以前的位置还是保留着,所以后面的
span元素
是显示在了div元素以前位置的后面
。 -
fixed
:表示固定定位
,与absolute(绝对)定位
类型类似,但它的相对移动的坐标是视图
(屏幕内的网页窗口
)本身。由于视图本身
是固定
的,它不会随浏览器窗口的滚动条滚动而变化,除非你在屏幕中移动浏览器窗口的屏幕位置,或改变浏览器窗口的显示大小,因此固定定位的元素会始终位于浏览器窗口内视图的某个位置
,不会受文档流动影响
,这与background-attachment:fixed;属性功能相同
。
<!DOCTYPE html>
<html lang="cn">
<head>
<meta charset="UTF-8">
<title>测试固定定位</title>
<style type="text/css" >
#div1 {
width:200px;
height: 200px;
border: 2px red solid;
position: fixed;
right: 100px; /*实现浏览器视图右下角定位div层*/
bottom: 50px;
}
</style>
</head>
<body>
<div id="div1"></div>
</body>
</html>
固定定位
- 相对于其它元素进行定位需要使用position:relative来帮忙,但是必须遵守下面规范:
1、参照定位的元素
必须是相对定位元素
的前辈元素
<div id="box1"><!--参照定位的元素-->
<div id="box2">相对参照元素进行定位</div><!--相对定位元素-->
</div>
2、参照定位的元素
必须加入position:relative
;
3、定位元素
加入position:absolute
,便可以使用top、bottom、left、right来进行偏移定位了。
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>相对参照元素进行定位</title>
<style type="text/css">
div{border:2px red solid;}
#box1{
width:200px;
height:200px;
position:relative;
}
#box2{
position:absolute;
top:20px;
left:30px;
}
#box3{
width:200px;
height:200px;
position:relative; /*父级元素要设置为相对定位*/
}
#box4{
width:99%;
position:absolute; /*子元素要设置为绝对定位*/
bottom:0;
}
</style>
</head>
<body>
<div id="box1">
<div id="box2">相对参照元素进行定位</div>
</div>
<h1>测试Relative与Absolute组合使用</h1>
<div id="box3">
<img src="timg.jpg" height="200px" width="200px">
<div id="box4">一张二次元图片</div>
<!--相对定位元素要为参照定位的子元素-->
</div>
</body>
</html>
Relative与Absolute组合使用
- 盒模型代码简写:
1、如果top、right、bottom、left的值相同,如下面代码:
margin:10px 10px 10px 10px;
/*可简写为:*/
margin:10px;
2、如果top
和bottom
值相同、left
和right
的值相同,如下面代码:
margin:10px 20px 10px 20px;
/*可简写为:*/
margin:10px 20px;
3、如果left和right的值相同,如下面代码:
margin:10px 20px 30px 20px; /*上右下左*/
/*可简写为:*/
margin:10px 20px 30px;
注意:padding
、border
的缩写方法和margin
是一致的。
-
颜色值缩写
,当你设置的颜色是16进制的色彩值时,如果每两位的值相同
,可缩写一半
。
p{color:#000000;}
p1{color: #336699;}
/*可简写为:*/
p{color: #000;}
p1{color: #369;}
-
字体缩写
:网页中的字体css样式代码也有它自己的缩写方式,下面是给网页设置字体的代码:
body{
font-style:italic;
font-variant:small-caps;
font-weight:bold;
font-size:12px;
line-height:1.5em;
font-family:"宋体",sans-serif;
}
/*可简写为:*/
body{
font:italic small-caps bold 12px/1.5em "宋体",sans-serif;
}
- 注意:
1、使用这一简写方式你至少要指定font-size
和font-family
属性,其他的属性(如font-weight
、font-style
、font-variant
、line-height
)如未指定将自动使用默认值
。
2、在缩写时font-size
与line-height
中间要加入“/
”斜扛。 - 一般情况下因为对于中文网站,英文还是比较少的,所以下面缩写代码比较常用:只是有
字号
、行间距
、中文字体
、英文字体
设置。
body{
font:12px/1.5em "宋体",sans-serif;
}
网友评论