html的div排列问题

html-css07

html的div排列问题,第1张

html中的div排版是通过css样式控制的。

DIV+CSS布局中主要CSS属性介绍:

Float:

Float属性是DIV+CSS布局中最基本也是最常用的属性,用于实现多列功能,我们知道<div>标签默认一行只能显示一个,而使用Float属性可以实现一行显示多个div的功能,最直接解释方法就是能实现表格布局的多列功能。

Margin:

Margin属性用于设置两个元素之间的距离。

Padding:

Padding属性用于设置一个元素的边框与其内容的距离。

Clear:

使用Float属性设置一行有多个DIV后(多列),最好在下一行开始之前使用Clear属性清楚一下浮动,否则上面的布局会影响到下面。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/htmlcharset=utf-8" />

<title>DIV+CSS布局教程</title>

<style type="text/css">

#Container{

width:1000px

margin:0 auto/*设置整个容器在浏览器中水平居中*/

background:#CF3

}

#Header{

height:80px

background:#093

}

#logo{

padding-left:50px

padding-top:20px

padding-bottom:50px

}

#Content{

height:600px

/*此处对容器设置了高度,一般不建议对容器设置高度,一般使用overflow:auto属性设置容器根据内容自适应高度,如果不指定高度或不设置自适应高度,容器将默认为1个字符高度,容器下方的布局元素(footer)设置margin-top:属性将无效*/

margin-top:20px/*此处讲解margin的用法,设置content与上面header元素之间的距离*/

background:#0FF

}

#Content-Left{

height:400px

width:200px

margin:20px/*设置元素跟其他元素的距离为20像素*/

float:left/*设置浮动,实现多列效果,div+Css布局中很重要的*/

background:#90C

}

#Content-Main{

height:400px

width:720px

margin:20px/*设置元素跟其他元素的距离为20像素*/

float:left/*设置浮动,实现多列效果,div+Css布局中很重要的*/

background:#90C

}

/*注:Content-Left和Content-Main元素是Content元素的子元素,两个元素使用了float:left设置成两列,这个两个元素的宽度和这个两个元素设置的padding、margin的和一定不能大于父层Content元素的宽度,否则设置列将失败*/

#Footer{

height:40px

background:#90C

margin-top:20px

}

.Clear{

clear:both

}

</style>

</head>

<body>

<div id="Container">

<div id="Header">

<div id="logo">这里设置了padding属性介绍一下padding的用法,padding将设置文本与边框的距离。</div>

</div>

<div id="Content">

<div id="Content-Left">Content-Left</div>

<div id="Content-Main">Content-Main</div>

</div>

<div class="Clear"><!--如何你上面用到float,下面布局开始前最好清除一下。--></div>

<div id="Footer">Footer</div>

</div>

</body>

</html>

运行效果:

div (division)就是html的一个标签而已。就和html里的其他标签如ul(无序列表),p(段落),table(表格),b(粗体)等等是一样的,只不过其他标签都是有语义的,div只是一个块级元素的代表,它在某种意义上代表html,所以一般教程会叫div+css,因为css是要结合html标签才能发挥作用的。

一个标签怎么会有一个单独的教程呢?