欢迎来到DIVCSS5查找CSS资料与学习DIV CSS布局技术!
  • <div> 是一个块级元素。这意味着它的内容自动地开始一个新行。实际上,换行是 <div> 固有的唯一格式表现。可以通过 <div> 的 class 或 id 应用额外的样式。
  • 如下代码是CSS通过id设置每个div的宽高和背景色
<!doctype html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Document</title>
 <style type="text/css">
 #a {
 width: 200px;
 height: 100px;
 background: red;
 }
 #b {
 width: 200px;
 height: 100px;
 background: blue;
 }
 #c {
 width: 200px;
 height: 100px;
 background: green;
 }
 </style>
</head>
<body>
 <div id="a"></div>
 <div id="b"></div>
 <div id="c"></div>
</body>
</html>

执行效果:

HTML的组成部分、DIV+CSS布局

 

浮动布局

我们先写两个div设置上背景颜色看看效果

<!doctype html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Document</title>
 <style type="text/css">
 #lside {
 height: 200px;
 background: red;
 }
 #rside {
 height: 200px;
 background: green;
 }
 </style>
</head>
<body>
 <div id="lside">我是左边</div>
 <div id="rside">我是右边</div>
</body>
</html>
HTML的组成部分、DIV+CSS布局

 

上文也说ddiv的内容会自动地开始一个新行,所以想将两个div左右排列就要进行浮动布局

我们分别在CSS中加上float属性

 <style type="text/css">
 #lside {
 height: 200px;
 background: red;
 float: left;
 }
 #rside {
 height: 200px;
 background: green;
 float: right;
 }
 </style>

效果如下图:

HTML的组成部分、DIV+CSS布局

 

清除浮动

当有浮动布局和普通div共同存在时,会发生如下覆盖的情况

<!doctype html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Document</title>
 <style type="text/css">
 #lside {
 height: 200px;
 background: red;
 float: left;
 }
 #rside {
 height: 300px;
 background: green;
 float: right;
 }
 #normal {
 height: 400px;
 background: blue;
 }
 </style>
</head>
<body>
 <div id="lside">我是左边</div>
 <div id="rside">我是右边</div>
 <div id="normal">我不设置浮动</div>
</body>
</html>
HTML的组成部分、DIV+CSS布局

 

所以如果不想被覆盖,就要清除浮动

在CSS中对普通元素设置clear属性

当我们增加 clear: left; 时,代表不让左边浮动盖着自己

 #normal {
 height: 400px;
 background: blue;
 clear: left;
 }

此时清除左浮的div就会贴着左浮的div下边显示,如图:

HTML的组成部分、DIV+CSS布局

 

同样的还可设置 clear: right; 代表不让右边浮动盖着自己;设置 clear: both; 代表不让浮动盖着自己。这里不做演示

如需转载,请注明文章出处和来源网址:http://www.divcss5.com/css-jiaocheng/tc58729.shtml