版权声明:本文为博主原创文章,未经博主同意不得转载。
https://blog.csdn.net/u012116457/article/details/28710173
请珍惜小编劳动成果,该文章为小编原创,转载请注明出处。
摘要:
CSS3相对CSS2添加了一些新的布局方式:多栏布局和盒子布局。在这篇文章中。将对CSS2的布局进行简单的回顾,并总结CSS3的布局方式。
DIV+CSS事实上是错误的叫法
关于当前的页面布局。非常多人都习惯于叫做DIV+CSS,事实上这是一种错误的叫法。标准叫法应该叫做XHTML+CSS.
这是为什么呢?传统的页面布局採用的是Table布局,即Table+CSS,后来出现了使用DIV的布局方式,所以人们就把它叫做DIV+CSS,并且有些人觉得用DIV+CSS制作的页面才是标准页面。事实上这句话是比較狭隘的。
这是为什么呢?传统的页面布局採用的是Table布局,即Table+CSS,后来出现了使用DIV的布局方式,所以人们就把它叫做DIV+CSS,并且有些人觉得用DIV+CSS制作的页面才是标准页面。事实上这句话是比較狭隘的。
那什么是标准页面呢?WEB标准由结构,表现和行为三部分组成。当中结构话标准语言是XHTML和XML,表现化标准语言是CSS。由于XML比較复杂。大多数浏览器都没有全然支持。故不使用XML来实现页面布局,所以标准的页面布局应该是符合WEB标准的页面布局,即XHTML+CSS。
而XHTML中不仅仅仅仅有DIV标签,还有a,p,ul,li,dl,dt等等标签,所以即使不使用DIV标签,制作的页面也是标准页面,XHTML的各个标签都有其功能,并非说仅仅能用DIV去实现页面布局(在一本书上有怎么一句话:假设满屏都是DIV,那也算不上标准页面了)
所以说。以后我们要尽可能的说XHTML+CSS。而不是DIV+CSS.
CSS2时代的布局方式
简单点说,CSS2时代是使用float的浮动属性来实现布局的。
layout.css
/* CSS Document */
/*基本信息*/
body{
margin:0px; /*外边距*/
text-align:center; /*文字居中对齐*/
background:#E1D0BB; /*背景色*/
}
/*页面层容器*/
#container{
80%;
height:100%;
margin-left:10%;
margin-right:10%;
background:#ABE0F1;
}
/*头部*/
#header{
100%;
height:15%;
margin:0px;
background:#FF0000;
}
#logo{
float:left; /*浮动属性,居左对齐,使其能够在同一行显示*/
60%;
height:80%;
margin:0px;
background:#E18CDD;
clear:left; /*取消左側浮动*/
}
#banner{
float:right; /*浮动属性,居右对齐。使其能够在同一行显示*/
38%;
height:80%;
margin:0px;
background:#8376D8;
clear:right; /*取消右側浮动*/
}
#menu{
100%;
height:5%;
margin:0px;
background:#00FF00;
}
#pageBody{
100%;
height:70%;
margin:0px;
background:#00FFFF;
}
#footer{
100%;
height:10%;
margin:0px;
background:#FFFF00;
}
<!DOCTYPE>
<html>
<head>
<meta charset="utf-8">
<title>布局</title>
<link href="style/layout.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="container">
<div id="header">
<div id="logo">
logo
</div>
<div id="banner">
banner
</div>
container
</div>
<div id="menu">
menu
</div>
<div id="pageBody">
</div>
<div id="footer">
footer
</div>
</div>
</body>
</html>
可是。使用float实现布局会有一些缺点,由于各个div是相互独立的。所以在一个div中添加一些内容后会使得无法对齐。CSS3提供了多栏布局和盒子布局来弥补这样的缺点。
多栏布局
layout.css
/* CSS Document */
/*基本信息*/
body{
margin:0px; /*外边距*/
text-align:center; /*文字居中对齐*/
background:#E1D0BB; /*背景色*/
}
/*页面层容器*/
#container{
80%;
height:100%;
margin-left:10%;
margin-right:10%;
background:#ABE0F1;
}
/*头部*/
#header{
100%;
height:15%;
margin:0px;
background:#FF0000;
}
#logo{
float:left; /*浮动属性,居左对齐,使其能够在同一行显示*/
60%;
height:80%;
margin:0px;
background:#E18CDD;
clear:left; /*取消左側浮动*/
}
#banner{
float:right; /*浮动属性,居右对齐,使其能够在同一行显示*/
38%;
height:80%;
margin:0px;
background:#8376D8;
clear:right; /*取消右側浮动*/
}
#menu{
100%;
height:5%;
margin:0px;
background:#00FF00;
}
#pageBody{
100%;
height:70%;
margin:0px;
background:#00FFFF;
-moz-column-count:4; /*多栏布局:火狐浏览器中须要的格式,表示列数*/
-moz-column-gap:10px; /*列之间的间隔*/
-moz-column-rule:1px solid red; /*在列之间加一条红色的线*/
-webkit-column-count:4; /*多栏布局:safari和chrome须要的格式*/
-webkit-column-gap:10px; /*列之间的间隔*/
-webkit-column-rule:1px solid red; /*在列之间加一条红色的线*/
}
#footer{
100%;
height:10%;
margin:0px;
background:#FFFF00;
}
layout.html
<!DOCTYPE>
<html>
<head>
<meta charset="utf-8">
<title>布局</title>
<link href="style/layout.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="container">
<div id="header">
<div id="logo">
logo
</div>
<div id="banner">
banner
</div>
container
</div>
<div id="menu">
menu
</div>
<div id="pageBody">
内容省略
</div>
<div id="footer">
footer
</div>
</div>
</body>
</html>
效果图:
盒子布局
hezi.css
/* CSS Document */
/*基本信息*/
body{
margin:0px; /*外边距*/
text-align:center; /*文字居中对齐*/
background:#E1D0BB; /*背景色*/
}
/*页面层容器*/
#container{
display:-moz-box;
display:-webkit-box;
}
#left_side{
200px;
height:200px;
margin:20px;
padding:50px;
background-color:#FF0000
}
#center_side{
200px;
height:200px;
margin:20px;
padding:50px;
background-color:#00FF00
}
#right_side{
200px;
height:200px;
margin:20px;
padding:50px;
background-color:#FFFF00;
}
#left_side,#center_side,#right_side{ /*实现盒子布局*/
-moz-box-sizing:border-box;
-webkit-box-sizing:border-box;
}
#down_left{
-moz-box-flex:1; /*可依据内容自己主动调整大小,实现弹性盒子。此为火狐下的格式*/
-webkit-box-flex:1;
padding:20px;
margin:20px;
background-color:blue;
}
#down_left{
-moz-box-sizing:border-box;
-webkit-box-sizing:border-box;
}
hexi.html<!DOCTYPE>
<html>
<head>
<meta charset="utf-8">
<title>布局</title>
<link href="style/hezi.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="container">
<div id="left_side">
百度
</div>
<div id="center_side">
谷歌
</div>
<div id="right_side">
淘宝
</div>
<div id="down_left">
亚马逊
</div>
</div>
</body>
</html>
效果图:
假设想要让盒子垂直分部,能够在将container改为:
#container{
display:-moz-box;
display:-webkit-box;
-moz-box-orient:vertical; /*垂直分布*/
-webkit-box-orient:vertical;
}