Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 765|回复: 0

CSS 文本

[复制链接]

该用户从未签到

发表于 2011-7-29 21:07:15 | 显示全部楼层 |阅读模式
这是一个链接</a></p>
</body> 文本属性可定义文本的外观。

通过文本属性,您可以改变文本的颜色、字符间距,对齐文本,装饰文本,对文本进行缩进,等等。


缩进文本

把 Web 页面上的段落的第一行缩进,这是一种最常用的文本格局化效果。

提供了 text-indent 属性,该属性可以利便地实现文本缩进。

通过使用 text-indent 属性,所有元素的第一行都可以缩进一个给定的长度,甚至该长度可以是负值。

这个属性最常见的用途是将段落的首行缩进,下面的规则会使所有段落的首行缩进 5 em:
[pre]p {text-indent: 5em;}[/pre]
留意:一般来说,可认为所有块级元素应用 text-indent,但无法将该属性应用于行内元素,图像之类的替代元素上也无法应用 text-indent 属性。不外,假如一个块级元素(好比段落)的首行中有一个图像,它会随该行的其余文本移动。

提示:假如想把一个行内元素的第一行“缩进”,可以用左内边距或外边距创造这种效果。

使用负值

text-indent 还可以设置为负值。利用这种技术,可以实现良多有趣的效果,好比“吊挂缩进”,即第一行吊挂在元素中余下部门的左边:
[pre]p {text-indent: -5em;}[/pre]
不外在为 text-indent 设置负值时要当心,假如对一个段落设置了负值,那么首行的某些文本可能会超出浏览器窗口的左边界。为了避免泛起这种显示题目,建议针对负缩进再设置一个外边距或一些内边距:
[pre]p {text-indent: -5em; padding-left: 5em;}[/pre]
使用百分比值

text-indent 可以使用所有长度单位,包括百分比值。

百分数要相对于缩进元素父元素的宽度。换句话说,假如将缩进值设置为 20%,所影响元素的第一行会缩进其父元素宽度的 20%。

在下例中,缩进值是父元素的 20%,即 100 个像素:
[pre]div {width: 500px;}
p {text-indent: 20%;}

<div>
<p>this is a paragragh</p>
</div>
[/pre]
继续

text-indent 属性可以继续,请考虑如下标记:
[pre]div#outer {width: 500px;}
div#inner {text-indent: 10%;}
p {width: 200px;}

<div id="outer">
<div id="inner">some text. some text. some text.
<p>this is a paragragh.</p>
</div>
</div>
[/pre]
以上标记中的段落也会缩进 50 像素,这是由于这个段落继续了 id 为 inner 的 div 元素的缩进值。



水平对齐

text-align 是一个基本的属性,它会影响一个元素中的文本行互相之间的对齐方式。它的前 3 个值相称直接,不外第 4 个和第 5 个则略有些复杂。

值 left、right 和 center 会导致元素中的文天职别左对齐、右对齐和居中。

西方语言都是从左向右读,所有 text-align 的默认值是 left。文本在左边界对齐,右边界呈锯齿状(称为“从左到右”文本)。对于希伯来语和阿拉伯语之类的的语言,text-align 则默以为 right,由于这些语言从右向左读。不出所料,center 会使每个文本行在元素中居中。

提示:将块级元素或表元素居中,要通过在这些元素上适当地设置左、右外边距来实现。

text-align:center 与 <CENTER>

您可能会以为 text-align:center 与 <CENTER> 元素的作用一样,但实际上二者大不相同。

<CENTER> 不仅影响文本,还会把整个元素居中。text-align 不会控制元素的对齐,而只影响内部内容。元素本身不会从一段移到另一端,只是其中的文本受影响。

justify

最后一个水平对齐属性是 justify。

在两端对齐文本中,文本行的左右两端都放在父元素的内边界上。然后,调整单词和字母间的距离,使各行的长度刚好相等。您也许已经留意到了,两端对齐文本在打印领域很常见。

需要留意的是,要由用户代办代理(而不是 )来确定两端对齐文本如何拉伸,以填满父元素左右边界之间的空间。如需了解详情,请参阅 text-align 属性参考页。



字距离

word-spacing 属性可以改变字(单词)之间的尺度距离。其默认值 normal 与设置值为 0 是一样的。

word-spacing 属性接受一个正长度值或负长度值。假如提供一个正长度值,那么字之间的距离就会增加。为 word-spacing 设置一个负值,会把它拉近:
[pre]p.spread {word-spacing: 30px;}
p.tight {word-spacing: -0.5em;}

<p class="spread">
This is a paragraph. The spaces between words will be increased.
</p>

<p class="tight">
This is a paragraph. The spaces between words will be decreased.
</p>
[/pre]
实例 TIY :增加或减少单词间距(字距离)

注释:如需深入理解 对“字”(word)的定义,请访问 word-spacing 属性参考页。



字母距离

letter-spacing 属性与 word-spacing 的区别在于,字母距离修改的是字符或字母之间的距离。

与 word-spacing 属性一样,letter-spacing 属性的可取值包括所有长度。默认枢纽字是 normal(这与 letter-spacing:0 相同)。输入的长度值会使字母之间的距离增加或减少指定的量:
[pre]h1 {letter-spacing: -0.5em}
h4 {letter-spacing: 20px}

<h1>This is header 1</h1>
<h4>This is header 4</h4>
[/pre]
实例 TIY :划定字符间距(字母距离)



字符转换

text-transform 属性处理文本的大小写。这个属性有 4 个值:


    [li]none
    [li]uppercase
    [li]lowercase
    [li]capitalize [/li]

默认值 none 对文本不做任何改动,将使用源文档中的原有大小写。顾名思义,uppercase 和 lowercase 将文本转换为全大写和全小写字符。最后,capitalize 只对每个单词的首字母大写。

作为一个属性,text-transform 可能无关紧要,不外假如您溘然决定把所有 h1 元素变为大写,这个属性就很有用。不必单独地修改所有 h1 元素的内容,只需使用 text-transform 为你完成这个修改:
[pre]h1 {text-transform: uppercase}[/pre]
使用 text-transform 有两方面的好处。首先,只需写一个简朴的规则来完成这个修改,而无需修改 h1 元素本身。其次,假如您以后决定将所有大小写再切换为原来的大小写,可以更轻易地完成修改。

实例 TIY :控制文本中字母的大小写



文本装饰

接下来,我们讨论 text-decoration 属性,这是一个很有意思的属性,它提供了良多非常有趣的行为。

text-decoration 有 5 个值:


    [li]none
    [li]underline
    [li]overline
    [li]line-through
    [li]blink [/li]

不出所料,underline 会对元素加下划线,就像 中的 U 元素一样。overline 的作用刚好相反,会在文本的顶端画一个上划线。值 line-through 则在文本中间画一个贯串线,等价于 中的 S 和 strike 元素。blink 会让文本闪烁,类似于 Netscape 支持的颇招非议的 blink 标记。

none 值会封闭原本应用到一个元素上的所有装饰。通常,无装饰的文本是默认外观,但也不老是这样。例如,链接默认地会有下划线。假如您但愿去掉超链接的下划线,可以使用以下 来做到这一点:
[pre]a {text-decoration: none;}[/pre]
留意:假如显式地用这样一个规则去掉链接的下划线,那么锚与正常文本之间在视觉上的独一差别就是颜色(至少默认是这样的,不外也不能完全保证其颜色肯定有区别)。

还可以在一个规则中结合多种装饰。假如但愿所有超链接既有下划线,又有上划线,则规则如下:
[pre]a:link a:visited {text-decoration: underline overline;}[/pre]
不外要留意的是,假如两个不同的装饰都与统一元素匹配,胜出规则的值会完全取代另一个值。请考虑以下的规则:
[pre]h2.stricken {text-decoration: line-through;}
h2 {text-decoration: underline overline;}
[/pre]
对于给定的规则,所有 class 为 stricken 的 h2 元素都只有一个贯串线装饰,而没有下划线和上划线,由于 text-decoration 值会替代而不是累积起来。



处理空缺符

white-space 属性会影响到用户代办代理对源文档中的空格、换行和 tab 字符的处理。

通过使用该属性,可以影响浏览器处理字之间和文本行之间的空缺符的方式。从某种程度上讲,默认的 X 处理已经完成了空缺符处理:它会把所有空缺符合并为一个空格。所以给定以下标记,它在 Web 浏览器中显示时,各个字之间只会显示一个空格,同时忽略元素中的换行:
[pre]<p>This     paragraph has    many
    spaces           in it.</p>[/pre]
可以用以下声显著式地设置这种默认行为:
[pre]p {white-space: normal;}[/pre]
上面的规则告诉浏览器按照寻常的做法去处理:丢掉多余的空缺符。假如给定这个值,换行字符(回车)会转换为空格,一行中多个空格的序列也会转换为一个空格。

实例 TIY :white-space: normal

值 pre

不外,假如将 white-space 设置为 pre,受这个属性影响的元素中,空缺符的处理就有所不同,其行为就像 X 的 pre 元素一样;空缺符不会被忽略。

假如 white-space 属性的值为 pre,浏览器将会留意额外的空格,甚至回车。在这个方面,而且仅在这个方面,任何元素都可以相称于一个 pre 元素。

实例 TIY :white-space: pre

留意:经测试,IE 7 以及更早版本的浏览器不支持该值,因此请使用非 IE 的浏览器来查看上面的实例。

值 nowrap

与之相对的值是 nowrap,它会防止元素中的文本换行,除非使用了一个 br 元素。在 中使用 nowrap 非常类似于 4 顶用 <td nowrap> 将一个表单元格设置为不能换行,不外 white-space 值可以应用到任何元素。

实例 TIY :white-space: nowrap

值 pre-wrap 和 pre-line

2.1 引入了值 pre-wrap 和 pre-line,这在以前版本的 中是没有的。这些值的作用是答应创作职员更好地控制空缺符处理。

假如元素的 white-space 设置为 pre-wrap,那么该元素中的文本会留存空缺符序列,但是文本行会正常地换行。假如设置为这个值,源文本中的行分隔符以及天生的行分隔符也会留存。pre-line 与 pre-wrap 相反,会像正常文本中一样合并空缺符序列,但留存换行符。

实例 TIY :white-space: pre-wrap

实例 TIY :white-space: pre-line

留意:我们在 IE7 和 FireFox2.0 浏览器中测试了上面的两个实例,但是结果是,值 pre-wrap 和 pre-line 都没有得到很好的支持。

总结

下面的表格总结了 white-space 属性的行为:

空缺符换行符自动换行
pre-line合并留存答应
normal合并忽略答应
nowrap合并忽略不答应
pre留存留存不答应
pre-wrap留存留存答应



文本方向

假如您阅读的是英文书籍,就会从左到右、从上到下地阅读,这就是英文的流方向。不外,并不是所有语言都如斯。我们知道古汉语就是从右到左来阅读的,当然还包括希伯来语和阿拉伯语等等。2 引入了一个属性来描述其方向性。

direction 属性影响块级元素中文本的书写方向、表中列布局的方向、内容水平填充其元素框的方向、以及两端对齐元素中最后一行的为止。

注释:对于行内元素,只有当 unicode-bidi 属性设置为 embed 或 bidi-override 时才会应用 direction 属性。

direction 属性有两个值:ltr 和 rtl。大多数情况下,默认值是 ltr,显示从左到右的文本。假如显示从右到左的文本,应使用值 rtl。



文本实例:


设置文本颜色
本例演示如何设置文本的颜色。

<>
<head>
<style type="text/">
body {color:red}
h1 {color:#00ff00}
p.ex {color:rgb(0,0,255)}
</style>
</head>

<body>
<h1>这是 heading 1</h1>
<p>这是一段普通的段落。请留意,该段落的文本是红色的。在 body 选择器中定义了本页面中的默认文本颜色。</p>
<p class="ex">该段落定义了 class="ex"。该段落中的文本是蓝色的。</p>
</body>
</>


设置文本的背景颜色
本例颜色如何设置部门文本的背景颜色。

<>
<head>
<style type="text/">
span.highlight
{
background-color:yellow
}
</style>
</head>

<body>
<p>
<span class="highlight">这是文本。</span> 这是文本。 这是文本。 这是文本。 这是文本。 这是文本。 这是文本。 这是文本。 这是文本。 这是文本。 这是文本。 这是文本。 这是文本。 这是文本。 这是文本。 这是文本。 这是文本。 <span class="highlight">这是文本。</span>
</p>
</body>
</>


划定字符间距
本例演示如何增加或减少字符间距。

<>

<head>
<style type="text/">
h1 {letter-spacing: -0.5em}
h4 {letter-spacing: 20px}
</style>
</head>

<body>
<h1>This is header 1</h1>
<h4>This is header 4</h4>
</body>

</>


使用百分比设置行间距
本例演示如何使用百分比值来设置段落中的行间距。

<>

<head>
<style type="text/">
p.small {line-height: 90%}
p.big {line-height: 200%}
</style>
</head>

<body>

<p>
这是拥有尺度行高的段落。
在大多数浏览器中默认行高大约是 110% 到 120%。
这是拥有尺度行高的段落。
这是拥有尺度行高的段落。
这是拥有尺度行高的段落。
这是拥有尺度行高的段落。
这是拥有尺度行高的段落。
</p>

<p class="small">
这个段落拥有更小的行高。
这个段落拥有更小的行高。
这个段落拥有更小的行高。
这个段落拥有更小的行高。
这个段落拥有更小的行高。
这个段落拥有更小的行高。
这个段落拥有更小的行高。
</p>

<p class="big">
这个段落拥有更大的行高。
这个段落拥有更大的行高。
这个段落拥有更大的行高。
这个段落拥有更大的行高。
这个段落拥有更大的行高。
这个段落拥有更大的行高。
这个段落拥有更大的行高。
</p>

</body>
</>


使用像素值设置行间距
本例演示如何使用像素值来设置段落中的行间距。

<>

<head>
<style type="text/">
p.small
  {
  line-height: 10px
  }
p.big
  {
  line-height: 30px
  }
</style>
</head>

<body>

<p>
这是拥有尺度行高的段落。
在大多数浏览器中默认行高大约是 20px。
这是拥有尺度行高的段落。
这是拥有尺度行高的段落。
这是拥有尺度行高的段落。
这是拥有尺度行高的段落。
这是拥有尺度行高的段落。
</p>

<p class="small">
这个段落拥有更小的行高。
这个段落拥有更小的行高。
这个段落拥有更小的行高。
这个段落拥有更小的行高。
这个段落拥有更小的行高。
这个段落拥有更小的行高。
这个段落拥有更小的行高。
</p>

<p class="big">
这个段落拥有更大的行高。
这个段落拥有更大的行高。
这个段落拥有更大的行高。
这个段落拥有更大的行高。
这个段落拥有更大的行高。
这个段落拥有更大的行高。
这个段落拥有更大的行高。
</p>

</body>
</>


使用数值来设置行间距
本例演示如何使用一个数值来设置段落中的行间距。

<>

<head>
<style type="text/">
p.small
{
line-height: 0.5
}
p.big
{
line-height: 2
}
</style>
</head>

<body>

<p>
这是拥有尺度行高的段落。
默认行高大约是 1。
这是拥有尺度行高的段落。
这是拥有尺度行高的段落。
这是拥有尺度行高的段落。
这是拥有尺度行高的段落。
这是拥有尺度行高的段落。
</p>

<p class="small">
这个段落拥有更小的行高。
这个段落拥有更小的行高。
这个段落拥有更小的行高。
这个段落拥有更小的行高。
这个段落拥有更小的行高。
这个段落拥有更小的行高。
这个段落拥有更小的行高。
</p>

<p class="big">
这个段落拥有更大的行高。
这个段落拥有更大的行高。
这个段落拥有更大的行高。
这个段落拥有更大的行高。
这个段落拥有更大的行高。
这个段落拥有更大的行高。
这个段落拥有更大的行高。
</p>

</body>
</>


对齐文本
本例演示如何对齐文本。

<>
<head>
<style type="text/">
h1 {text-align: center}
h2 {text-align: left}
h3 {text-align: right}
</style>
</head>

<body>
<h1>这是标题 1</h1>
<h2>这是标题 2</h2>
<h3>这是标题 3</h3>
</body>

</>


润饰文本
本例演示如何向文本添加润饰。

<>
<head>
<style type="text/">
h1 {text-decoration: overline}
h2 {text-decoration: line-through}
h3 {text-decoration: underline}
h4 {text-decoration:blink}
a {text-decoration: none}
</style>
</head>

<body>
<h1>这是标题 1</h1>
<h2>这是标题 2</h2>
<h3>这是标题 3</h3>
<h4>这是标题 4</h4>
<p><a href=

</HTMLhtmlcSSHtmlhtmlcsshtmlhtmlcsshtmlhtmlcsshtmlcss>


缩进文本
本例演示如何缩进文本首行。

<>
<head>
<style type="text/">
p {text-indent: 1cm}
</style>
</head>

<body>
<p>
这是段落中的一些文本。
这是段落中的一些文本。
这是段落中的一些文本。
这是段落中的一些文本。
这是段落中的一些文本。
这是段落中的一些文本。
这是段落中的一些文本。
这是段落中的一些文本。
这是段落中的一些文本。
这是段落中的一些文本。
这是段落中的一些文本。
这是段落中的一些文本。
</p>
</body>

</>


控制文本中的字母
本例演示如何控制文本中的字母。

<>

<head>
<style type="text/">
  h1 {text-transform: uppercase}
  p.uppercase {text-transform: uppercase}
  p.lowercase {text-transform: lowercase}
  p.capitalize {text-transform: capitalize}
</style>
</head>

<body>
<h1>This Is An H1 Element</h1>
<p class="uppercase">This is some text in a paragraph.</p>
<p class="lowercase">This is some text in a paragraph.</p>
<p class="capitalize">This is some text in a paragraph.</p>
</body>

</>


在元素中禁止文本折行
本例演示如何禁止在元素中的文本折行。

<>
<head>
<style type="text/">
p
{
white-space: nowrap
}
</style>
</head>
<body>

<p>
这是一些文本。
这是一些文本。
这是一些文本。
这是一些文本。
这是一些文本。
这是一些文本。
这是一些文本。
这是一些文本。
这是一些文本。
这是一些文本。
这是一些文本。
这是一些文本。
</p>

</body>
</>


增加单词间距
本例演示如何增加段落中单词间的间隔。

<>
<head>
<style type="text/">
p.spread {word-spacing: 30px;}
p.tight {word-spacing: -0.5em;}
</style>
</head>

<body>
<p class="spread">This is some text. This is some text.</p>
<p class="tight">This is some text. This is some text.</p>
</body>
</>




文本属性

属性描述
color设置文本颜色
direction设置文本方向。
line-height设置行高。
letter-spacing设置字符间距。
text-align对齐元素中的文本。
text-decoration向文本添加润饰。
text-indent缩进元素中文本的首行。
text-shadow设置文本暗影。csscss2 包含该属性,但是 2.1 没有留存该属性。
text-transform控制元素中的字母。
unicode-bidi设置文本方向。
white-space设置元素中空缺的处理方式。
word-spacing设置字间距。
回复

使用道具 举报

  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2011-7-29 21:42:00 | 显示全部楼层
    谢谢楼主分享。
    回复 支持 反对

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-11 06:17 , Processed in 0.305493 second(s), 34 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表