※定义间距
前面说了如何用CSS定义字体、颜色和背景属性,那么定义好的文本我们怎么对它进行排版呢?
下面我们讲述一下CSS的文本属性(文本属性详细列表见后文),包括文字间距、字母间距、装饰、对齐方式、缩进方式和行高等属性。 例如下面这段文字(如左下图):
我们对这段文字加上文本属性重新排版,排版后的效果如右上图所示。
我们看到经过文本属性处理的文本字与字之间多了间距,行与行之间多了行高,对齐方式变成了两端对齐,并且段首又多缩进了两格。这是怎样实现的呢?很简单,只是在html中加了如下的代码:
<p
style=“letter-spacing:1em;text-align:justify;text-indent:
4em;line-height:17pt”>……</p>
//*letter-spacing设置了字间距为1em,其中1em为一个长度单位;text-align设置了对齐方式为两端对齐;indent设置了缩进格为4em;line-height设置了行高为
17pt*//
从上例我们可以看出利用CSS的文本属性可以方便的对页面中的文本进行排版。下面向您介绍文本的Text-decoration属性的一个小应用。
※装饰超链接
网页默认的链接方式是这样的:未访问过的链接是蓝色文字并带蓝色的下划线,访问过的超级链接是深紫色的文字并带深紫色的下划线。如果您所有的网页都是这种样式,是不是很单调呢?
其实,利用文本属性中的Text-decoration属性就可以实现对超链接的修饰。我们先看下面的这段代码:
<html>
<title>link css</title>
<head>
<style>
<!--
//*定义伪类元素(a:),大括号内定义了前景色属性和文本装饰属性,
hover加上‘font-size’属性目的是让鼠标激活链接时改变字体*//
a:link{color:green;text-decoration:none}
//*未访问时的状态,颜色为绿色(green),文本装饰属性(text-decoration)值
为没有(none)*//
a:visited{color:red;text-decoration:none}
//*访问过的状态,颜色为红色(red),文本装饰属性值为没有*//
a:hover{color:blue;text-decoration:overline;font-size:20pt}
//*鼠标激活的状态,颜色为蓝色(blue),
文本装饰属性值为上划(overline),
字体大小为20pt*//
-->
</style>
</head>
<body>
<p style=“font-family:行书体;font-size:18pt”>
<a
href=“http://www.hongen.com”>未访问的链接</a></p>
//*加链接,显示三种不同状态,并且定义了链接文本的字体和大小*//
<p> <a
href=“http://www.hongen.com”>访问过的链接</a></p>
<p> <a
href=“http://www.hongen.com”>鼠标激活的链接</a></p>
</body>
</html>
我们从例子中看到没有访问过的链接以绿色显示,并且去掉了下划线;而访问过的链接以红色且没有下划线显示;另外,当鼠标激活链接时,链接以蓝色显示,并且加上了上划线。这种效果是怎么实现的呢?它除了运用了文本属性中的text-decoration属性,而且采用了伪类元素。
通过上面的代码注释,相信您应该对伪类元素有一个大概认识。实际上我们用到的这种伪类应当称之为“锚伪类”,它规定了链接不同状态下的效果。
怎么样,是不是很简单的就可以实现动态链接的效果,赶紧自己动手试一试吧!下面向您介绍“容器”属性。
五、“容器”属性
※边距属性
什么叫“容器”属性呢?CSS的容器属性包括边距、填充距、边框和宽度、高度、浮动、清除等属性。
您想,网页中的内容肯定是都需要“装”进这个“容器”里。“容器”属性是CSS中非常重要的一种属性,我们将分类进行学习,(容器属性详细列表见后文)。
和font属性一样,表中的四个属性可以用一个属性一次。边距顺序是上、右、下、左。我们还是用定义边距属性前后的两个例子来看一下吧。请看下面的这幅图:
http://www.hongen.com/pc/homepage/css/img/css012.gif
我们看到上图是没有加上边距属性的效果,而下图则在<head>中加入了如下代码:
body{margin:1em 2em 3em 4em}
//*定义文本的上、右、下、左的边距分别为1、2、3、4em*//
产生的效果如下图所示:
http://www.hongen.com/pc/homepage/css/img/css011.gif
定义了边距后的页面,无论您怎么改变窗口的大小,它都会按照您定义好的边距样式显示。如果在margin里有缺失的属性,则按照顺序依次排列。比如:
body{margin:1em 3em}
※填充距属性
本节我将向您介绍填充距属性(填充距属性详细列表见后文)。
http://www.hongen.com/pc/homepage/css/img/css013.gif
我们看到上图中红框圈住的地方就是填充距起作用的部分。实际上上图的效果只是在上一节例子的<head>中把下面这段代码加入到Body定义的margin后面:
padding:1em 2em 3em 4em
从上可以看出,红框标记外的部分属于margin属性在起作用。
下面向您介绍边框属性。
※边框属性
本节我们来看一下种类繁多的边框属性(边框属性详细列表见后文)。看上去很多,其实应用起来很方便。
只要灵活的运用一次定义的属性就会方便很多。其实还有一个一次设置所有边框的宽度、样式和颜色属性的border属性,但是border只能使四条边框的属性值是一样的。我们现在来给前面的例子设置一个5像素宽、双边框并且是紫色的边框(如下图):
http://www.hongen.com/pc/homepage/css/img/css014.gif
这就是在<head>中定义<p>的属性,代码如下:
P{border:5px double
purple}//*定义了四条边框为一样的值*//
您还可以找一段文本自己多尝试一下其他的边框属性,看看还有什么效果。
※图文混排
“容器”属性中的float属性很有意思,它能实现在图片那里插入了一个表格才实现的图文混排效果。在这里只是在<head>中定义了一下<img>的float和margin属性,代码如下:
<html>
<title>margin css</title>
<head>
<style>
<!--
img{margin-right:2em;float:left}
//*定义图片的右边距为2em,图片浮动在文字的左边*//
-->
</style>
</head>
<body>
<p class=“p2” style=“line-height:17pt”>
<img src=“logo.gif” alt=“floating” >
我公司是一家以软件开发及销售为主业的高新技术企业。拥有近4000平米的独立办公楼,全体员工年轻勤奋而富有创造力,极具挑战性和竞争性。</p>
</body>
</html>
怎么样,不用表格也能实现图文混排的效果,并且减少了大量的代码。您还可以试试float的其他效果。
好了,“容器”属性就讲这么多,我们可以看出,充分利用CSS的“容器”属性,将会使您的页面布局更加合理,样式更加漂亮。

加载中…