Qt样式表的使用

来源:互联网 发布:linux防御xorddos 编辑:程序博客网 时间:2024/06/09 22:11
 Qt中可以灵活的使用层叠样式表(CSS),其语法和CSS很相似。因为HTML CSS的灵活性,所以可以很方便的为QT界面设计自己需要的外观。除了子类化Style类,使用QT样式表(QStyleSheet)是另一种快速改变QT程序UI风格的方法,它很大程度上借鉴和参考了 HTML层叠样式表的语法和思想。

  StyleSheet文件的默认后缀名为qss,可通过命令行参数 -stylesheet filename.qss 来设置样式表,也可通过QApplication::setStyleSheetQWidget::setStyleSheet来设置应用程序或特定控件要使用的样式表。::setStyleSheet函数的参数是字符串(不是qss文件的名字,而是样式表的内容),所以直接使用的话,不方便一次设置大量的规则,但可使用资源文件将qss样式表嵌入到程序中,然后通过QApplication::setStyleSheet来使用。

  下面简单介绍Qt样式表(QSS)的使用。

1、在当前工程目录下建立.qss格式的文件,如:css.qss,在其中编写Qt支持的CSS代码,如下所示:

QPushButton:hover{    color:yellow;    background-color:green;}QPushButton[text="Cancel"]{    color:red;}QTableView::item:hover,QLineEdit:hover,QComboBox:hover,QTextEdit:hover{    background-color:rgb(127,255,212);}QMenuBar,QStatusBar{    background-color:rgb(100,149,237);}

2、在Qt程序中设置该样式表

  在Qt程序的合适位置添加如下代码:

//读取样式表QFile qssFile("css.qss");//资源文件":/css.qss"qssFile.open(QFile::ReadOnly);if(qssFile.isOpen()){    QString qss = QLatin1String(qssFile.readAll());    qApp->setStyleSheet(qss);    qssFile.close();}

  在程序中可通过qApp设置样式表,也可通过控件对象设置样式表。

3、QSS语法

  同CSS一样,它也由Selector和Declaration组成,如:

QPushButton {     color: red;}

  若有几个Selector指定了相同的Declaration,可使用逗号将Selector选择器分开,如:

QPushButton, QLineEdit, QComboBox{     color: red; }

注:

  CSS的语法请参见:http://www.w3school.com.cn/css/css_syntax.asp

  Qt Style Sheets的详细介绍请参见官网:http://doc.qt.io/qt-4.8/stylesheet.html

 

CSS 基础语法

CSS 语法

CSS 规则由两个主要的部分构成:选择器,以及一条或多条声明。

selector {declaration1; declaration2; ... declarationN }

选择器通常是您需要改变样式的 HTML 元素。

每条声明由一个属性和一个值组成。

属性(property)是您希望设置的样式属性(style attribute)。每个属性有一个值。属性和值被冒号分开。

selector {property: value}

下面这行代码的作用是将 h1 元素内的文字颜色定义为红色,同时将字体大小设置为 14 像素。

在这个例子中,h1 是选择器,color 和 font-size 是属性,red 和 14px 是值。

h1 {color:red; font-size:14px;}

下面的示意图为您展示了上面这段代码的结构:

CSS 语法

提示:请使用花括号来包围声明。

值的不同写法和单位

除了英文单词 red,我们还可以使用十六进制的颜色值 #ff0000:

p { color: #ff0000; }

为了节约字节,我们可以使用 CSS 的缩写形式:

p { color: #f00; }

我们还可以通过两种方法使用 RGB 值:

p { color: rgb(255,0,0); }p { color: rgb(100%,0%,0%); }

请注意,当使用 RGB 百分比时,即使当值为 0 时也要写百分比符号。但是在其他的情况下就不需要这么做了。比如说,当尺寸为 0 像素时,0 之后不需要使用 px 单位,因为 0 就是 0,无论单位是什么。

记得写引号

提示:如果值为若干单词,则要给值加引号:

p {font-family: "sans serif";}

多重声明:

提示:如果要定义不止一个声明,则需要用分号将每个声明分开。下面的例子展示出如何定义一个红色文字的居中段落。最后一条规则是不需要加分号的,因为分号在英语中是一个分隔符号,不是结束符号。然而,大多数有经验的设计师会在每条声明的末尾都加上分号,这么做的好处是,当你从现有的规则中增减声明时,会尽可能地减少出错的可能性。就像这样:

p {text-align:center; color:red;}

你应该在每行只描述一个属性,这样可以增强样式定义的可读性,就像这样:

p {  text-align: center;  color: black;  font-family: arial;}

空格和大小写

大多数样式表包含不止一条规则,而大多数规则包含不止一个声明。多重声明和空格的使用使得样式表更容易被编辑:

body {  color: #000;  background: #fff;  margin: 0;  padding: 0;  font-family: Georgia, Palatino, serif;  }

是否包含空格不会影响 CSS 在浏览器的工作效果,同样,与 XHTML 不同,CSS 对大小写不敏感。不过存在一个例外:如果涉及到与 HTML 文档一起工作的话,class 和 id 名称对大小写是敏感的。

 

选择器的分组

你可以对选择器进行分组,这样,被分组的选择器就可以分享相同的声明。用逗号将需要分组的选择器分开。在下面的例子中,我们对所有的标题元素进行了分组。所有的标题元素都是绿色的。

h1,h2,h3,h4,h5,h6 {  color: green;  }

继承及其问题

根据 CSS,子元素从父元素继承属性。但是它并不总是按此方式工作。看看下面这条规则:

body {     font-family: Verdana, sans-serif;     }

根据上面这条规则,站点的 body 元素将使用 Verdana 字体(假如访问者的系统中存在该字体的话)。

通过 CSS 继承,子元素将继承最高级元素(在本例中是 body)所拥有的属性(这些子元素诸如 p, td, ul, ol, ul, li, dl, dt,和 dd)。不需要另外的规则,所有 body 的子元素都应该显示 Verdana 字体,子元素的子元素也一样。并且在大部分的现代浏览器中,也确实是这样的。

但是在那个浏览器大战的血腥年代里,这种情况就未必会发生,那时候对标准的支持并不是企业的优先选择。比方说,Netscape 4 就不支持继承,它不仅忽略继承,而且也忽略应用于 body 元素的规则。IE/Windows 直到 IE6 还存在相关的问题,在表格内的字体样式会被忽略。我们又该如何是好呢?

友善地对待Netscape 4

幸运地是,你可以通过使用我们称为 "Be Kind to Netscape 4" 的冗余法则来处理旧式浏览器无法理解继承的问题。

body  {     font-family: Verdana, sans-serif;     }p, td, ul, ol, li, dl, dt, dd  {     font-family: Verdana, sans-serif;     }

4.0 浏览器无法理解继承,不过他们可以理解组选择器。这么做虽然会浪费一些用户的带宽,但是如果需要对 Netscape 4 用户进行支持,就不得不这么做。

继承是一个诅咒吗?

如果你不希望 "Verdana, sans-serif" 字体被所有的子元素继承,又该怎么做呢?比方说,你希望段落的字体是 Times。没问题。创建一个针对 p 的特殊规则,这样它就会摆脱父元素的规则:

body { font-family: Verdana, sans-serif; }td, ul, ol, ul, li, dl, dt, dd { font-family: Verdana, sans-serif; }p { font-family: Times, "Times New Roman", serif; }

 

派生选择器

通过依据元素在其位置的上下文关系来定义样式,你可以使标记更加简洁。

在 CSS1 中,通过这种方式来应用规则的选择器被称为上下文选择器 (contextual selectors),这是由于它们依赖于上下文关系来应用或者避免某项规则。在 CSS2 中,它们称为派生选择器,但是无论你如何称呼它们,它们的作用都是相同的。

派生选择器允许你根据文档的上下文关系来确定某个标签的样式。通过合理地使用派生选择器,我们可以使 HTML 代码变得更加整洁。

比方说,你希望列表中的 strong 元素变为斜体字,而不是通常的粗体字,可以这样定义一个派生选择器:

li strong {    font-style: italic;    font-weight: normal;  }

请注意标记为 <strong> 的蓝色代码的上下文关系:

<p><strong>我是粗体字,不是斜体字,因为我不在列表当中,所以这个规则对我不起作用</strong></p><ol><li><strong>我是斜体字。这是因为 strong 元素位于 li 元素内。</strong></li><li>我是正常的字体。</li></ol>

在上面的例子中,只有 li 元素中的 strong 元素的样式为斜体字,无需为 strong 元素定义特别的 class 或 id,代码更加简洁。

再看看下面的 CSS 规则:

strong {     color: red;     }h2 {     color: red;     }h2 strong {     color: blue;     }

下面是它施加影响的 HTML:

<p>The strongly emphasized word in this paragraph is<strong>red</strong>.</p><h2>This subhead is also red.</h2><h2>The strongly emphasized word in this subhead is<strong>blue</strong>.</h2>

相关内容

如果您需要更深入地学习关于派生选择器的知识,请阅读 W3School 的高级教程中的以下内容:

  • CSS 后代选择器
  • CSS 子元素选择器
  • CSS 相邻兄弟选择器

    id 选择器

    id 选择器可以为标有特定 id 的 HTML 元素指定特定的样式。

    id 选择器以 "#" 来定义。

    下面的两个 id 选择器,第一个可以定义元素的颜色为红色,第二个定义元素的颜色为绿色:

    #red {color:red;}#green {color:green;}

    下面的 HTML 代码中,id 属性为 red 的 p 元素显示为红色,而 id 属性为 green 的 p 元素显示为绿色。

    <p id="red">这个段落是红色。</p><p id="green">这个段落是绿色。</p>

    注意:id 属性只能在每个 HTML 文档中出现一次。想知道原因吗,请参阅 XHTML:网站重构。

    id 选择器和派生选择器

    在现代布局中,id 选择器常常用于建立派生选择器。

    #sidebar p {font-style: italic;text-align: right;margin-top: 0.5em;}

    上面的样式只会应用于出现在 id 是 sidebar 的元素内的段落。这个元素很可能是 div 或者是表格单元,尽管它也可能是一个表格或者其他块级元素。它甚至可以是一个内联元素,比如 <em></em> 或者 <span></span>,不过这样的用法是非法的,因为不可以在内联元素 <span> 中嵌入 <p> (如果你忘记了原因,请参阅XHTML:网站重构)。

    一个选择器,多种用法

    即使被标注为 sidebar 的元素只能在文档中出现一次,这个 id 选择器作为派生选择器也可以被使用很多次:

    #sidebar p {font-style: italic;text-align: right;margin-top: 0.5em;}#sidebar h2 {font-size: 1em;font-weight: normal;font-style: italic;margin: 0;line-height: 1.5;text-align: right;}

    在这里,与页面中的其他 p 元素明显不同的是,sidebar 内的 p 元素得到了特殊的处理,同时,与页面中其他所有 h2 元素明显不同的是,sidebar 中的 h2 元素也得到了不同的特殊处理。

    单独的选择器

    id 选择器即使不被用来创建派生选择器,它也可以独立发挥作用:

    #sidebar {border: 1px dotted #000;padding: 10px;}

    根据这条规则,id 为 sidebar 的元素将拥有一个像素宽的黑色点状边框,同时其周围会有 10 个像素宽的内边距(padding,内部空白)。老版本的 Windows/IE 浏览器可能会忽略这条规则,除非你特别地定义这个选择器所属的元素:

    div#sidebar {border: 1px dotted #000;padding: 10px;}

    在 CSS 中,类选择器以一个点号显示:

    .center {text-align: center}

    在上面的例子中,所有拥有 center 类的 HTML 元素均为居中。

    在下面的 HTML 代码中,h1 和 p 元素都有 center 类。这意味着两者都将遵守 ".center" 选择器中的规则。

    <h1 class="center">This heading will be center-aligned</h1><p class="center">This paragraph will also be center-aligned.</p>

    注意:类名的第一个字符不能使用数字!它无法在 Mozilla 或 Firefox 中起作用。

    和 id 一样,class 也可被用作派生选择器:

    .fancy td {color: #f60;background: #666;}

    在上面这个例子中,类名为 fancy 的更大的元素内部的表格单元都会以灰色背景显示橙色文字。(名为 fancy 的更大的元素可能是一个表格或者一个 div)

    元素也可以基于它们的类而被选择:

    td.fancy {color: #f60;background: #666;}

    在上面的例子中,类名为 fancy 的表格单元将是带有灰色背景的橙色。

    <td class="fancy">

    你可以将类 fancy 分配给任何一个表格元素任意多的次数。那些以 fancy 标注的单元格都会是带有灰色背景的橙色。那些没有被分配名为 fancy 的类的单元格不会受这条规则的影响。还有一点值得注意,class 为 fancy 的段落也不会是带有灰色背景的橙色,当然,任何其他被标注为 fancy 的元素也不会受这条规则的影响。这都是由于我们书写这条规则的方式,这个效果被限制于被标注为 fancy 的表格单元(即使用 td 元素来选择 fancy 类)。

     

    对带有指定属性的 HTML 元素设置样式。

    可以为拥有指定属性的 HTML 元素设置样式,而不仅限于 class 和 id 属性。

    注释:只有在规定了 !DOCTYPE 时,IE7 和 IE8 才支持属性选择器。在 IE6 及更低的版本中,不支持属性选择。

    属性选择器

    下面的例子为带有 title 属性的所有元素设置样式:

    [title]{color:red;}

    亲自试一试

    属性和值选择器

    下面的例子为 title="W3School" 的所有元素设置样式:

    [title=W3School]{border:5px solid blue;}

    亲自试一试

    属性和值选择器 - 多个值

    下面的例子为包含指定值的 title 属性的所有元素设置样式。适用于由空格分隔的属性值:

    [title~=hello] { color:red; }

    亲自试一试

    下面的例子为带有包含指定值的 lang 属性的所有元素设置样式。适用于由连字符分隔的属性值:

    [lang|=en] { color:red; }

    亲自试一试

    设置表单的样式

    属性选择器在为不带有 class 或 id 的表单设置样式时特别有用:

    input[type="text"]{  width:150px;  display:block;  margin-bottom:10px;  background-color:yellow;  font-family: Verdana, Arial;}input[type="button"]{  width:120px;  margin-left:35px;  display:block;  font-family: Verdana, Arial;}

    亲自试一试

    CSS 选择器参考手册

    选择器描述[attribute]用于选取带有指定属性的元素。[attribute=value]用于选取带有指定属性和值的元素。[attribute~=value]用于选取属性值中包含指定词汇的元素。[attribute|=value]用于选取带有以指定值开头的属性值的元素,该值必须是整个单词。[attribute^=value]匹配属性值以指定值开头的每个元素。[attribute$=value]匹配属性值以指定值结尾的每个元素。[attribute*=value]匹配属性值中包含指定值的每个元素。
    • CSS 类选择器

      如何插入样式表

      当读到一个样式表时,浏览器会根据它来格式化 HTML 文档。插入样式表的方法有三种:

      外部样式表

      当样式需要应用于很多页面时,外部样式表将是理想的选择。在使用外部样式表的情况下,你可以通过改变一个文件来改变整个站点的外观。每个页面使用 <link> 标签链接到样式表。<link> 标签在(文档的)头部:

      <head><link rel="stylesheet" type="text/css" href="mystyle.css" /></head>

      浏览器会从文件 mystyle.css 中读到样式声明,并根据它来格式文档。

      外部样式表可以在任何文本编辑器中进行编辑。文件不能包含任何的 html 标签。样式表应该以 .css 扩展名进行保存。下面是一个样式表文件的例子:

      hr {color: sienna;}p {margin-left: 20px;}body {background-image: url("images/back40.gif");}

      不要在属性值与单位之间留有空格。假如你使用 “margin-left: 20 px” 而不是 “margin-left: 20px” ,它仅在 IE 6 中有效,但是在 Mozilla/Firefox 或 Netscape 中却无法正常工作。

      内部样式表

      当单个文档需要特殊的样式时,就应该使用内部样式表。你可以使用 <style> 标签在文档头部定义内部样式表,就像这样:

      <head><style type="text/css">  hr {color: sienna;}  p {margin-left: 20px;}  body {background-image: url("images/back40.gif");}</style></head>

      内联样式

      由于要将表现和内容混杂在一起,内联样式会损失掉样式表的许多优势。请慎用这种方法,例如当样式仅需要在一个元素上应用一次时。

      要使用内联样式,你需要在相关的标签内使用样式(style)属性。Style 属性可以包含任何 CSS 属性。本例展示如何改变段落的颜色和左外边距:

      <p style="color: sienna; margin-left: 20px">This is a paragraph</p>

      多重样式

      如果某些属性在不同的样式表中被同样的选择器定义,那么属性值将从更具体的样式表中被继承过来。

      例如,外部样式表拥有针对 h3 选择器的三个属性:

      h3 {  color: red;  text-align: left;  font-size: 8pt;  }

      而内部样式表拥有针对 h3 选择器的两个属性:

      h3 {  text-align: right;   font-size: 20pt;  }

      假如拥有内部样式表的这个页面同时与外部样式表链接,那么 h3 得到的样式是:

      color: red; text-align: right; font-size: 20pt;

      即颜色属性将被继承于外部样式表,而文字排列(text-alignment)和字体尺寸(font-size)会被内部样式表中的规则取代。

       

      CSS 允许应用纯色作为背景,也允许使用背景图像创建相当复杂的效果。

      CSS 在这方面的能力远远在 HTML 之上。

      背景色

      可以使用 background-color 属性为元素设置背景色。这个属性接受任何合法的颜色值。

      这条规则把元素的背景设置为灰色:

      p {background-color: gray;}

      如果您希望背景色从元素中的文本向外少有延伸,只需增加一些内边距:

      p {background-color: gray; padding: 20px;}

      如需查看本例的效果,可以亲自试一试!

      可以为所有元素设置背景色,这包括 body 一直到 em 和 a 等行内元素。

      background-color 不能继承,其默认值是 transparent。transparent 有“透明”之意。也就是说,如果一个元素没有指定背景色,那么背景就是透明的,这样其祖先元素的背景才能可见。

      背景图像

      要把图像放入背景,需要使用 background-image 属性。background-image 属性的默认值是 none,表示背景上没有放置任何图像。

      如果需要设置一个背景图像,必须为这个属性设置一个 URL 值:

      body {background-image: url(/i/eg_bg_04.gif);}

      大多数背景都应用到 body 元素,不过并不仅限于此。

      下面例子为一个段落应用了一个背景,而不会对文档的其他部分应用背景:

      p.flower {background-image: url(/i/eg_bg_03.gif);}

      您甚至可以为行内元素设置背景图像,下面的例子为一个链接设置了背景图像:

      a.radio {background-image: url(/i/eg_bg_07.gif);}

      如需查看上述例子的效果,可以亲自试一试!

      理论上讲,甚至可以向 textareas 和 select 等替换元素的背景应用图像,不过并不是所有用户代理都能很好地处理这种情况。

      另外还要补充一点,background-image 也不能继承。事实上,所有背景属性都不能继承。

      背景重复

      如果需要在页面上对背景图像进行平铺,可以使用 background-repeat 属性。

      属性值 repeat 导致图像在水平垂直方向上都平铺,就像以往背景图像的通常做法一样。repeat-x 和 repeat-y 分别导致图像只在水平或垂直方向上重复,no-repeat 则不允许图像在任何方向上平铺。

      默认地,背景图像将从一个元素的左上角开始。请看下面的例子:

      body  {   background-image: url(/i/eg_bg_03.gif);  background-repeat: repeat-y;  }

      如需查看上例的效果,可以亲自试一试。

      背景定位

      可以利用 background-position 属性改变图像在背景中的位置。

      下面的例子在 body 元素中将一个背景图像居中放置:

      body  {     background-image:url('/i/eg_bg_03.gif');    background-repeat:no-repeat;    background-position:center;  }

      为 background-position 属性提供值有很多方法。首先,可以使用一些关键字:top、bottom、left、right 和 center。通常,这些关键字会成对出现,不过也不总是这样。还可以使用长度值,如 100px 或 5cm,最后也可以使用百分数值。不同类型的值对于背景图像的放置稍有差异。

      关键字

      图像放置关键字最容易理解,其作用如其名称所表明的。例如,top right 使图像放置在元素内边距区的右上角。

      根据规范,位置关键字可以按任何顺序出现,只要保证不超过两个关键字 - 一个对应水平方向,另一个对应垂直方向。

      如果只出现一个关键字,则认为另一个关键字是 center。

      所以,如果希望每个段落的中部上方出现一个图像,只需声明如下:

      p  {     background-image:url('bgimg.gif');    background-repeat:no-repeat;    background-position:top;  }

      下面是等价的位置关键字:

      单一关键字等价的关键字centercenter centertoptop center 或 center topbottombottom center 或 center bottomrightright center 或 center rightleftleft center 或 center left

      百分数值

      百分数值的表现方式更为复杂。假设你希望用百分数值将图像在其元素中居中,这很容易:

      body  {     background-image:url('/i/eg_bg_03.gif');    background-repeat:no-repeat;    background-position:50% 50%;  }

      这会导致图像适当放置,其中心与其元素的中心对齐。换句话说,百分数值同时应用于元素和图像。也就是说,图像中描述为 50% 50% 的点(中心点)与元素中描述为 50% 50% 的点(中心点)对齐。

      如果图像位于 0% 0%,其左上角将放在元素内边距区的左上角。如果图像位置是 100% 100%,会使图像的右下角放在右边距的右下角。

      因此,如果你想把一个图像放在水平方向 2/3、垂直方向 1/3 处,可以这样声明:

      body  {     background-image:url('/i/eg_bg_03.gif');    background-repeat:no-repeat;    background-position:66% 33%;  }

      如果只提供一个百分数值,所提供的这个值将用作水平值,垂直值将假设为 50%。这一点与关键字类似。

      background-position 的默认值是 0% 0%,在功能上相当于 top left。这就解释了背景图像为什么总是从元素内边距区的左上角开始平铺,除非您设置了不同的位置值。

      长度值

      长度值解释的是元素内边距区左上角的偏移。偏移点是图像的左上角。

      比如,如果设置值为 50px 100px,图像的左上角将在元素内边距区左上角向右 50 像素、向下 100 像素的位置上:

      body  {     background-image:url('/i/eg_bg_03.gif');    background-repeat:no-repeat;    background-position:50px 100px;  }

      注意,这一点与百分数值不同,因为偏移只是从一个左上角到另一个左上角。也就是说,图像的左上角与 background-position 声明中的指定的点对齐。

      背景关联

      如果文档比较长,那么当文档向下滚动时,背景图像也会随之滚动。当文档滚动到超过图像的位置时,图像就会消失。

      您可以通过 background-attachment 属性防止这种滚动。通过这个属性,可以声明图像相对于可视区是固定的(fixed),因此不会受到滚动的影响:

      body   {  background-image:url(/i/eg_bg_02.gif);  background-repeat:no-repeat;  background-attachment:fixed  }

      如需查看上例的效果,可以亲自试一试。

      background-attachment 属性的默认值是 scroll,也就是说,在默认的情况下,背景会随文档滚动。

      CSS 背景实例

      设置背景颜色
      本例演示如何为元素设置背景颜色。
      设置文本的背景颜色
      本例颜色如何设置部分文本的背景颜色。
      将图像设置为背景
      本例演示如何将图像设置为背景。
      将图像设置为背景 2
      本例演示如何为多个元素同时设置背景图像。
      如何重复背景图像
      本例演示如何重复背景图像。
      如何在垂直方向重复背景图像
      本例演示如何垂直地重复背景图像。
      如何在水平方向重复背景图像
      本例演示如何水平地重复背景图像。
      如何仅显示一次背景图像
      本例演示如何仅显示一次背景图像。
      如何放置背景图像
      本例演示如何在页面上放置背景图像。
      如何使用%来定位背景图像
      本例演示如何使用百分比来在页面上定位背景图像。
      如何使用像素来定位背景图像
      本例演示如何使用像素来在页面上定位背景图像。
      如何设置固定的背景图像
      本例演示如何设置固定的背景图像。图像不会随着页面的其他部分滚动。
      所有背景属性在一个声明之中
      本例演示如何使用简写属性来将所有背景属性设置在一个声明之中。

      CSS 背景属性

      属性描述background简写属性,作用是将背景属性设置在一个声明中。background-attachment背景图像是否固定或者随着页面的其余部分滚动。background-color设置元素的背景颜色。background-image把图像设置为背景。background-position设置背景图像的起始位置。background-repeat设置背景图像是否及如何重复。

       

      CSS 文本属性可定义文本的外观。

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

      缩进文本

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

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

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

      这个属性最常见的用途是将段落的首行缩进,下面的规则会使所有段落的首行缩进 5 em:

      p {text-indent: 5em;}

      注意:一般来说,可以为所有块级元素应用 text-indent,但无法将该属性应用于行内元素,图像之类的替换元素上也无法应用 text-indent 属性。不过,如果一个块级元素(比如段落)的首行中有一个图像,它会随该行的其余文本移动。

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

      使用负值

      text-indent 还可以设置为负值。利用这种技术,可以实现很多有趣的效果,比如“悬挂缩进”,即第一行悬挂在元素中余下部分的左边:

      p {text-indent: -5em;}

      不过在为 text-indent 设置负值时要当心,如果对一个段落设置了负值,那么首行的某些文本可能会超出浏览器窗口的左边界。为了避免出现这种显示问题,建议针对负缩进再设置一个外边距或一些内边距:

      p {text-indent: -5em; padding-left: 5em;}

      使用百分比值

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

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

      在下例中,缩进值是父元素的 20%,即 100 个像素:

      div {width: 500px;}p {text-indent: 20%;}<div><p>this is a paragragh</p></div>

      继承

      text-indent 属性可以继承,请考虑如下标记:

      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>

      以上标记中的段落也会缩进 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。

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

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

      字间隔

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

      word-spacing 属性接受一个正长度值或负长度值。如果提供一个正长度值,那么字之间的间隔就会增加。为 word-spacing 设置一个负值,会把它拉近:

      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>

      实例 TIY :增加或减少单词间距(字间隔)

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

      字母间隔

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

      与 word-spacing 属性一样,letter-spacing 属性的可取值包括所有长度。默认关键字是 normal(这与 letter-spacing:0 相同)。输入的长度值会使字母之间的间隔增加或减少指定的量:

      h1 {letter-spacing: -0.5em}h4 {letter-spacing: 20px}<h1>This is header 1</h1><h4>This is header 4</h4>

      实例 TIY :规定字符间距(字母间隔)

      字符转换

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

      • none
      • uppercase
      • lowercase
      • capitalize

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

      作为一个属性,text-transform 可能无关紧要,不过如果您突然决定把所有 h1 元素变为大写,这个属性就很有用。不必单独地修改所有 h1 元素的内容,只需使用 text-transform 为你完成这个修改:

      h1 {text-transform: uppercase}

      使用 text-transform 有两方面的好处。首先,只需写一个简单的规则来完成这个修改,而无需修改 h1 元素本身。其次,如果您以后决定将所有大小写再切换为原来的大小写,可以更容易地完成修改。

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

      文本装饰

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

      text-decoration 有 5 个值:

      • none
      • underline
      • overline
      • line-through
      • blink

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

      none 值会关闭原本应用到一个元素上的所有装饰。通常,无装饰的文本是默认外观,但也不总是这样。例如,链接默认地会有下划线。如果您希望去掉超链接的下划线,可以使用以下 CSS 来做到这一点:

      a {text-decoration: none;}

      注意:如果显式地用这样一个规则去掉链接的下划线,那么锚与正常文本之间在视觉上的唯一差别就是颜色(至少默认是这样的,不过也不能完全保证其颜色肯定有区别)。

      还可以在一个规则中结合多种装饰。如果希望所有超链接既有下划线,又有上划线,则规则如下:

      a:link a:visited {text-decoration: underline overline;}

      不过要注意的是,如果两个不同的装饰都与同一元素匹配,胜出规则的值会完全取代另一个值。请考虑以下的规则:

      h2.stricken {text-decoration: line-through;}h2 {text-decoration: underline overline;}

      对于给定的规则,所有 class 为 stricken 的 h2 元素都只有一个贯穿线装饰,而没有下划线和上划线,因为 text-decoration 值会替换而不是累积起来

      处理空白符

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

      通过使用该属性,可以影响浏览器处理字之间和文本行之间的空白符的方式。从某种程度上讲,默认的 XHTML 处理已经完成了空白符处理:它会把所有空白符合并为一个空格。所以给定以下标记,它在 Web 浏览器中显示时,各个字之间只会显示一个空格,同时忽略元素中的换行:

      <p>This     paragraph has    many    spaces           in it.</p>

      可以用以下声明显式地设置这种默认行为:

      p {white-space: normal;}

      上面的规则告诉浏览器按照平常的做法去处理:丢掉多余的空白符。如果给定这个值,换行字符(回车)会转换为空格,一行中多个空格的序列也会转换为一个空格。

      实例 TIY :white-space: normal

      值 pre

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

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

      实例 TIY :white-space: pre

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

      值 nowrap

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

      实例 TIY :white-space: nowrap

      值 pre-wrap 和 pre-line

      CSS2.1 引入了值 pre-wrap 和 pre-line,这在以前版本的 CSS 中是没有的。这些值的作用是允许创作人员更好地控制空白符处理。

      如果元素的 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保留保留允许

      文本方向

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

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

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

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

      CSS 文本实例:

      设置文本颜色
      本例演示如何设置文本的颜色。
      设置文本的背景颜色
      本例颜色如何设置部分文本的背景颜色。
      规定字符间距
      本例演示如何增加或减少字符间距。
      使用百分比设置行间距
      本例演示如何使用百分比值来设置段落中的行间距。
      使用像素值设置行间距
      本例演示如何使用像素值来设置段落中的行间距。
      使用数值来设置行间距
      本例演示如何使用一个数值来设置段落中的行间距。
      对齐文本
      本例演示如何对齐文本。
      修饰文本
      本例演示如何向文本添加修饰。
      缩进文本
      本例演示如何缩进文本首行。
      控制文本中的字母
      本例演示如何控制文本中的字母。
      在元素中禁止文本折行
      本例演示如何禁止在元素中的文本折行。
      增加单词间距
      本例演示如何增加段落中单词间的距离。

      CSS 文本属性

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

       

      CSS 字体属性定义文本的字体系列、大小、加粗、风格(如斜体)和变形(如小型大写字母)。

      CSS 字体系列

      在 CSS 中,有两种不同类型的字体系列名称:

      • 通用字体系列 - 拥有相似外观的字体系统组合(比如 "Serif" 或 "Monospace")
      • 特定字体系列 - 具体的字体系列(比如 "Times" 或 "Courier")

      除了各种特定的字体系列外,CSS 定义了 5 种通用字体系列:

      • Serif 字体
      • Sans-serif 字体
      • Monospace 字体
      • Cursive 字体
      • Fantasy 字体

      如果需要了解更多有关字体系列的知识,请阅读 CSS 字体系列。

      指定字体系列

      使用 font-family 属性 定义文本的字体系列。

      使用通用字体系列

      如果你希望文档使用一种 sans-serif 字体,但是你并不关心是哪一种字体,以下就是一个合适的声明:

      body {font-family: sans-serif;}

      亲自试一试

      这样用户代理就会从 sans-serif 字体系列中选择一个字体(如 Helvetica),并将其应用到 body 元素。因为有继承,这种字体选择还将应用到 body 元素中包含的所有元素,除非有一种更特定的选择器将其覆盖。

      指定字体系列

      除了使用通用的字体系列,您还可以通过 font-family 属性设置更具体的字体。

      下面的例子为所有 h1 元素设置了 Georgia 字体:

      h1 {font-family: Georgia;}

      亲自试一试

      这样的规则同时会产生另外一个问题,如果用户代理上没有安装 Georgia 字体,就只能使用用户代理的默认字体来显示 h1 元素。

      我们可以通过结合特定字体名和通用字体系列来解决这个问题:

      h1 {font-family: Georgia, serif;}

      亲自试一试

      如果读者没有安装 Georgia,但安装了 Times 字体(serif 字体系列中的一种字体),用户代理就可能对 h1 元素使用 Times。尽管 Times 与 Georgia 并不完全匹配,但至少足够接近。

      因此,我们建议在所有 font-family 规则中都提供一个通用字体系列。这样就提供了一条后路,在用户代理无法提供与规则匹配的特定字体时,就可以选择一个候选字体。

      如果您对字体非常熟悉,也可以为给定的元素指定一系列类似的字体。要做到这一点,需要把这些字体按照优先顺序排列,然后用逗号进行连接:

      p {font-family: Times, TimesNR, 'New Century Schoolbook',     Georgia, 'New York', serif;}

      亲自试一试

      根据这个列表,用户代理会按所列的顺序查找这些字体。如果列出的所有字体都不可用,就会简单地选择一种可用的 serif 字体。

      使用引号

      您也许已经注意到了,上面的例子中使用了单引号。只有当字体名中有一个或多个空格(比如 New York),或者如果字体名包括 # 或 $ 之类的符号,才需要在 font-family 声明中加引号。

      单引号或双引号都可以接受。但是,如果把一个 font-family 属性放在 HTML 的 style 属性中,则需要使用该属性本身未使用的那种引号:

      <p style="font-family: Times, TimesNR, 'New Century Schoolbook', Georgia, 'New York', serif;">...</p>

      亲自试一试

      字体风格

      font-style 属性最常用于规定斜体文本。

      该属性有三个值:

      • normal - 文本正常显示
      • italic - 文本斜体显示
      • oblique - 文本倾斜显示

      实例

      p.normal {font-style:normal;}p.italic {font-style:italic;}p.oblique {font-style:oblique;}

      亲自试一试

      italic 和 oblique 的区别

      font-style 非常简单:用于在 normal 文本、italic 文本和 oblique 文本之间选择。唯一有点复杂的是明确 italic 文本和 oblique 文本之间的差别。

      斜体(italic)是一种简单的字体风格,对每个字母的结构有一些小改动,来反映变化的外观。与此不同,倾斜(oblique)文本则是正常竖直文本的一个倾斜版本。

      通常情况下,italic 和 oblique 文本在 web 浏览器中看上去完全一样。

      字体变形

      font-variant 属性可以设定小型大写字母。

      小型大写字母不是一般的大写字母,也不是小写字母,这种字母采用不同大小的大写字母。

      实例

      p {font-variant:small-caps;}

      亲自试一试

      字体加粗

      font-weight 属性设置文本的粗细。

      使用 bold 关键字可以将文本设置为粗体。

      关键字 100 ~ 900 为字体指定了 9 级加粗度。如果一个字体内置了这些加粗级别,那么这些数字就直接映射到预定义的级别,100 对应最细的字体变形,900 对应最粗的字体变形。数字 400 等价于 normal,而 700 等价于 bold。

      如果将元素的加粗设置为 bolder,浏览器会设置比所继承值更粗的一个字体加粗。与此相反,关键词 lighter 会导致浏览器将加粗度下移而不是上移。

      实例

      p.normal {font-weight:normal;}p.thick {font-weight:bold;}p.thicker {font-weight:900;}

      亲自试一试

      字体大小

      font-size 属性设置文本的大小。

      有能力管理文本的大小在 web 设计领域很重要。但是,您不应当通过调整文本大小使段落看上去像标题,或者使标题看上去像段落。

      请始终使用正确的 HTML 标题,比如使用 <h1> - <h6> 来标记标题,使用 <p> 来标记段落。

      font-size 值可以是绝对或相对值。

      绝对值:

      • 将文本设置为指定的大小
      • 不允许用户在所有浏览器中改变文本大小(不利于可用性)
      • 绝对大小在确定了输出的物理尺寸时很有用

      相对大小:

      • 相对于周围的元素来设置大小
      • 允许用户在浏览器改变文本大小

      注意:如果您没有规定字体大小,普通文本(比如段落)的默认大小是 16 像素 (16px=1em)。

      使用像素来设置字体大小

      通过像素设置文本大小,可以对文本大小进行完全控制:

      实例

      h1 {font-size:60px;}h2 {font-size:40px;}p {font-size:14px;}

      亲自试一试

      在 Firefox, Chrome, and Safari 中,可以重新调整以上例子的文本大小,但是在 Internet Explorer 中不行。

      虽然可以通过浏览器的缩放工具调整文本大小,但是这实际上是对整个页面的调整,而不仅限于文本。

      使用 em 来设置字体大小

      如果要避免在 Internet Explorer 中无法调整文本的问题,许多开发者使用 em 单位代替 pixels。

      W3C 推荐使用 em 尺寸单位。

      1em 等于当前的字体尺寸。如果一个元素的 font-size 为 16 像素,那么对于该元素,1em 就等于 16 像素。在设置字体大小时,em 的值会相对于父元素的字体大小改变。

      浏览器中默认的文本大小是 16 像素。因此 1em 的默认尺寸是 16 像素。

      可以使用下面这个公式将像素转换为 em:pixels/16=em

      (注:16 等于父元素的默认字体大小,假设父元素的 font-size 为 20px,那么公式需改为:pixels/20=em

      实例

      h1 {font-size:3.75em;} /* 60px/16=3.75em */h2 {font-size:2.5em;}  /* 40px/16=2.5em */p {font-size:0.875em;} /* 14px/16=0.875em */

      亲自试一试

      在上面的例子中,以 em 为单位的文本大小与前一个例子中以像素计的文本是相同的。不过,如果使用 em 单位,则可以在所有浏览器中调整文本大小。

      不幸的是,在 IE 中仍存在问题。在重设文本大小时,会比正常的尺寸更大或更小。

      结合使用百分比和 EM

      在所有浏览器中均有效的方案是为 body 元素(父元素)以百分比设置默认的 font-size 值:

      实例

      body {font-size:100%;}h1 {font-size:3.75em;}h2 {font-size:2.5em;}p {font-size:0.875em;}

      亲自试一试

      我们的代码非常有效。在所有浏览器中,可以显示相同的文本大小,并允许所有浏览器缩放文本的大小。

      CSS 字体实例:

      设置文本的字体
      本例演示如何设置文本字体。
      设置字体尺寸
      本例演示如何设置字体尺寸。
      设置字体风格
      本例演示如何设置字体风格。
      设置字体的异体
      本例演示如何设置字体的异体。
      设置字体的粗细
      本例演示如何设置字体的粗细。
      所有字体属性在一个声明之内
      本例演示如何使用简写属性将字体属性设置在一个声明之内。

      CSS 字体属性

      属性描述font简写属性。作用是把所有针对字体的属性设置在一个声明中。font-family设置字体系列。font-size设置字体的尺寸。font-size-adjust当首选字体不可用时,对替换字体进行智能缩放。(CSS2.1 已删除该属性。)font-stretch对字体进行水平拉伸。(CSS2.1 已删除该属性。)font-style设置字体风格。font-variant以小型大写字体或者正常字体显示文本。font-weight设置字体的粗细。
      • CSS 文本

        我们能够以不同的方法为链接设置样式。

        设置链接的样式

        能够设置链接样式的 CSS 属性有很多种(例如 color, font-family, background 等等)。

        链接的特殊性在于能够根据它们所处的状态来设置它们的样式。

        链接的四种状态:

        • a:link - 普通的、未被访问的链接
        • a:visited - 用户已访问的链接
        • a:hover - 鼠标指针位于链接的上方
        • a:active - 链接被点击的时刻

        实例

        a:link {color:#FF0000;}/* 未被访问的链接 */a:visited {color:#00FF00;}/* 已被访问的链接 */a:hover {color:#FF00FF;}/* 鼠标指针移动到链接上 */a:active {color:#0000FF;}/* 正在被点击的链接 */

        亲自试一试

        当为链接的不同状态设置样式时,请按照以下次序规则:

        • a:hover 必须位于 a:link 和 a:visited 之后
        • a:active 必须位于 a:hover 之后

        常见的链接样式

        在上面的例子中,链接根据其状态改变颜色。

        让我们看看其他几种常见的设置链接样式的方法:

        文本修饰

        text-decoration 属性大多用于去掉链接中的下划线:

        实例

        a:link {text-decoration:none;}a:visited {text-decoration:none;}a:hover {text-decoration:underline;}a:active {text-decoration:underline;}

        亲自试一试

        背景色

        background-color 属性规定链接的背景色:

        实例

        a:link {background-color:#B2FF99;}a:visited {background-color:#FFFF85;}a:hover {background-color:#FF704D;}a:active {background-color:#FF704D;}

        亲自试一试

        更多实例

        向链接添加不同的样式
        本例演示如何向链接添加其他样式。
        高级 - 创建链接框
        本例演示了更高级的示例,我们结合了若干种 CSS 属性,来把链接显示为方框。

        CSS 列表属性允许你放置、改变列表项标志,或者将图像作为列表项标志。

        CSS 列表

        从某种意义上讲,不是描述性的文本的任何内容都可以认为是列表。人口普查、太阳系、家谱、参观菜单,甚至你的所有朋友都可以表示为一个列表或者是列表的列表。

        由于列表如此多样,这使得列表相当重要,所以说,CSS 中列表样式不太丰富确实是一大憾事。

        列表类型

        要影响列表的样式,最简单(同时支持最充分)的办法就是改变其标志类型。

        例如,在一个无序列表中,列表项的标志 (marker) 是出现在各列表项旁边的圆点。在有序列表中,标志可能是字母、数字或另外某种计数体系中的一个符号。

        要修改用于列表项的标志类型,可以使用属性 list-style-type:

        ul {list-style-type : square}

        上面的声明把无序列表中的列表项标志设置为方块。

        列表项图像

        有时,常规的标志是不够的。你可能想对各标志使用一个图像,这可以利用 list-style-image 属性做到:

        ul li {list-style-image : url(xxx.gif)}

        只需要简单地使用一个 url() 值,就可以使用图像作为标志。

        列表标志位置

        CSS2.1 可以确定标志出现在列表项内容之外还是内容内部。这是利用 list-style-position 完成的。

        简写列表样式

        为简单起见,可以将以上 3 个列表样式属性合并为一个方便的属性:list-style,就像这样:

        li {list-style : url(example.gif) square inside}

        list-style 的值可以按任何顺序列出,而且这些值都可以忽略。只要提供了一个值,其它的就会填入其默认值。

        CSS 列表实例:

        在无序列表中的不同类型的列表标记
        本例演示在CSS中不同类型的列表项标记。
        在有序列表中不同类型的列表项标记
        本例演示在CSS中不同类型的列表项标记。
        所有的列表样式类型
        本例演示在CSS中所有不同类型的列表项标记。
        将图像作为列表项标记
        本例演示如何将图像作为列表项标记。
        放置列表标记
        本例演示在何处放置列表标记。
        在一个声明中定义所有的列表属性
        本例演示将所有针对列表的属性设置于一个简写属性。

        CSS 列表属性(list)

        属性描述list-style简写属性。用于把所有用于列表的属性设置于一个声明中。list-style-image将图象设置为列表项标志。list-style-position设置列表中列表项标志的位置。list-style-type设置列表项标志的类型。marker-offset 
        • CSS 链接

         

        CSS 表格属性可以帮助您极大地改善表格的外观。

        表格边框

        如需在 CSS 中设置表格边框,请使用 border 属性。

        下面的例子为 table、th 以及 td 设置了蓝色边框:

        table, th, td  {  border: 1px solid blue;  }

        亲自试一试

        请注意,上例中的表格具有双线条边框。这是由于 table、th 以及 td 元素都有独立的边框。

        如果需要把表格显示为单线条边框,请使用 border-collapse 属性。

        折叠边框

        border-collapse 属性设置是否将表格边框折叠为单一边框:

        table  {  border-collapse:collapse;  }table,th, td  {  border: 1px solid black;  }

        亲自试一试

        表格宽度和高度

        通过 width 和 height 属性定义表格的宽度和高度。

        下面的例子将表格宽度设置为 100%,同时将 th 元素的高度设置为 50px:

        table  {  width:100%;  }th  {  height:50px;  }

        亲自试一试

        表格文本对齐

        text-align 和 vertical-align 属性设置表格中文本的对齐方式。

        text-align 属性设置水平对齐方式,比如左对齐、右对齐或者居中:

        td  {  text-align:right;  }

        亲自试一试

        vertical-align 属性设置垂直对齐方式,比如顶部对齐、底部对齐或居中对齐:

        td  {  height:50px;  vertical-align:bottom;  }

        亲自试一试

        表格内边距

        如需控制表格中内容与边框的距离,请为 td 和 th 元素设置 padding 属性:

        td  {  padding:15px;  }

        亲自试一试

        表格颜色

        下面的例子设置边框的颜色,以及 th 元素的文本和背景颜色:

        table, td, th  {  border:1px solid green;  }th  {  background-color:green;  color:white;  }

        亲自试一试

        CSS Table 属性

        属性描述border-collapse设置是否把表格边框合并为单一的边框。border-spacing设置分隔单元格边框的距离。caption-side设置表格标题的位置。empty-cells设置是否显示表格中的空单元格。table-layout设置显示单元、行和列的算法。

        亲自试一试 - 更多实例

        制作一个漂亮的表格
        本例演示如何创造一个漂亮的表格。
        显示表格中的空单元
        本例演示是否显示表格中的空单元。
        设置表格边框之间的空白
        本例演示如何设置单元格边框之间的距离。
        设置表格标题的位置
        本例演示如何定位表格的标题。
         
        0 0
        原创粉丝点击