当前位置: 代码迷 >> HTML/CSS >> css+div小小小结
  详细解决方案

css+div小小小结

热度:38   发布时间:2012-09-19 13:43:53.0
css+div小小总结
在html语言中分为块级元素(例如div),内联元素(例如span),
块级元素:就是一个方块,像段落一样,默认占据一行出现;

内联元素:又叫行内元素,顾名思义,只能放在行内,就像一个单词,不会造成前后换行,起辅助作用。

一般的块级元素诸如段落<p>、标题<h1><h2>...、列表,<ul><ol><li> 、表格<table>、表单<form>、DIV<div>和BODY<body>等元素。而内联元素则如: 表单元素<input>、超级链接<a>、图像<img>、<span> ........ 块级无素的显著特点是:每个块级元素都是从一个新行开始显示,而且其后的无素也需另起一行进行显示。



从上图的例子可以看出,块级元素默认占据一行,相当于在它之前和之后各插入了一个换行;而内联元素span没对显示效果造成任何影响,事实也是如此;em只是让字体变成了斜体,也没有单独占据一行。这就是块级元素和内联元素,正因为有了这些元素,才使我们的网页变得丰富多彩。

如果没有css的作用,块元素会顺序以每次另起一行的方式一直往下排。而有了css以后,我们可以改变这种html的默认布局模式,把块元素摆放到你想要的位置上去。而不是每次都愚蠢的另起一行。也就是说,可以用css的display:inline将块级元素改变为内联元素,也可以用display:block将内联元素改变为块元素。
   

     正因为div是块级元素,在组成html页面时,如果没有css的话div就只能简简单单的上下排列,正因为有了css才使网页更丰富,css可以用盒装模型来描述看附件:
另外,加载css样式有以下四种
外部样式
内部样式
行内样式
导入样式
<link href="layout.css" rel="stylesheet" type="text/css" />

这种形式是把css单独写到一个css文件内,然后在源代码中以link方式链接。它的好处是不但本页可以调用,其它页面也可以调用,是最常用的一种形式。

<style>
h2 { color:#f00;}
</style>

这种形式是内部样式表,它是以<style>和</style>结尾,写在源代码的head标签内。这样的样式表只能针对本页有效。不能作用于其它页面。

<p style="font-size:18px;">内部样式</p>

这种在标签内以style标记的为行内样式,行内样式只针对标签内的元素有效,因其没有和内容相分离,所以不建议使用。

@import url("/css/global.css");

链接样式是以@import url标记所链接的外部样式表,它一般常用在另一个样式表内部。如layout.css为主页所用样式,那么我们可以把全局都需要用的公共样式放到一个global.css的文件中,然后在layout.css中以@import url("/css/global.css")的形式链接全局样式,这样就使代码达到很好的重用性。
   此外,css有三种类型分别是:id(只用与一个元素,例如某一个div用#作为前缀)class(用于页面的任何元素,调用时使用)标签(用于整个文档的所有的元素,直接应用,不需调用)
       float属性回到我们的例子当中,理解了块级元素和内联元素,对理解浮动就容易多了。float是个重点,希望大家都能理解。上例中用float让元素向左浮动,在 CSS 中,任何元素都可以浮动。浮动元素会生成一个块级框,而不论它本身是何种元素;且要指明一个宽度,否则它会尽可能地窄;另外当可供浮动的空间小于浮动元素时,它会跑到下一行,直到拥有足够放下它的空间。


     如果 一行有三个div,第一个与第三个分别为左浮动,右浮动,中间的div margin-left margin-right均可以不写出(但如果是三个固定宽度的div排列一定要写出这一属性,否则会跑到下一行,不会在同行显示),但有时候写与不写会产生不同的效果,如果有一段文字在第二个div中,如果文字显示不下,在加margin属性的情况下,超出的文字会与上面对齐。具体看附件“第三天 两列与三列布局”
   



  相关解决方案