Qt中可以灵活的使用层叠样式表(CSS),其语法和CSS很相似。因为HTML CSS的灵活性,所以可以很方便的为QT界面设计自己需要的外观。除了子类化Style类,使用QT样式表(QStyleSheet)是另一种快速改变QT程序UI风格的方法,它很大程度上借鉴和参考了 HTML层叠样式表的语法和思想。
StyleSheet文件的默认后缀名为qss,可通过命令行参数 -stylesheet filename.qss 来设置样式表,也可通过QApplication::setStyleSheet或QWidget::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 规则由两个主要的部分构成:选择器,以及一条或多条声明。
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;}
下面的示意图为您展示了上面这段代码的结构:
提示:请使用花括号来包围声明。
除了英文单词 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 还存在相关的问题,在表格内的字体样式会被忽略。我们又该如何是好呢?
幸运地是,你可以通过使用我们称为 "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 元素位于 li 元素内。
- 我是正常的字体。
在上面的例子中,只有 li 元素中的 strong 元素的样式为斜体字,无需为 strong 元素定义特别的 class 或 id,代码更加简洁。
再看看下面的 CSS 规则:
strong {
color: red;
}
h2 {
color: red;
}
h2 strong
{
color: blue;
}
下面是它施加影响的 HTML:
The strongly emphasized word in this paragraph isred.
This subhead is also red.
The strongly emphasized word in this subhead is
blue
.
如果您需要更深入地学习关于派生选择器的知识,请阅读 W3School 的高级教程中的以下内容:
id 选择器可以为标有特定 id 的 HTML 元素指定特定的样式。
id 选择器以 "#" 来定义。
下面的两个 id 选择器,第一个可以定义元素的颜色为红色,第二个定义元素的颜色为绿色:
#red
{color:red;}#green
{color:green;}
下面的 HTML 代码中,id 属性为 red 的 p 元素显示为红色,而 id 属性为 green 的 p 元素显示为绿色。
id="red">这个段落是红色。
id="green">这个段落是绿色。
注意:id 属性只能在每个 HTML 文档中出现一次。想知道原因吗,请参阅 XHTML:网站重构。
在现代布局中,id 选择器常常用于建立派生选择器。
#sidebar p
{
font-style: italic;
text-align: right;
margin-top: 0.5em;
}
上面的样式只会应用于出现在 id 是 sidebar 的元素内的段落。这个元素很可能是 div 或者是表格单元,尽管它也可能是一个表格或者其他块级元素。它甚至可以是一个内联元素,比如 或者 ,不过这样的用法是非法的,因为不可以在内联元素 中嵌入 (如果你忘记了原因,请参阅 XHTML:网站重构)。 即使被标注为 sidebar 的元素只能在文档中出现一次,这个 id 选择器作为派生选择器也可以被使用很多次: 在这里,与页面中的其他 p 元素明显不同的是,sidebar 内的 p 元素得到了特殊的处理,同时,与页面中其他所有 h2 元素明显不同的是,sidebar 中的 h2 元素也得到了不同的特殊处理。 id 选择器即使不被用来创建派生选择器,它也可以独立发挥作用: 根据这条规则,id 为 sidebar 的元素将拥有一个像素宽的黑色点状边框,同时其周围会有 10 个像素宽的内边距(padding,内部空白)。老版本的 Windows/IE 浏览器可能会忽略这条规则,除非你特别地定义这个选择器所属的元素: 在 CSS 中,类选择器以一个点号显示: 在上面的例子中,所有拥有 center 类的 HTML 元素均为居中。 在下面的 HTML 代码中,h1 和 p 元素都有 center 类。这意味着两者都将遵守 ".center" 选择器中的规则。 class="center">
This paragraph will also be center-aligned.
注意:类名的第一个字符不能使用数字!它无法在 Mozilla 或 Firefox 中起作用。 和 id 一样,class 也可被用作派生选择器: 在上面这个例子中,类名为 fancy 的更大的元素内部的表格单元都会以灰色背景显示橙色文字。(名为 fancy 的更大的元素可能是一个表格或者一个 div) 元素也可以基于它们的类而被选择: 在上面的例子中,类名为 fancy 的表格单元将是带有灰色背景的橙色。 你可以将类 fancy 分配给任何一个表格元素任意多的次数。那些以 fancy 标注的单元格都会是带有灰色背景的橙色。那些没有被分配名为 fancy 的类的单元格不会受这条规则的影响。还有一点值得注意,class 为 fancy 的段落也不会是带有灰色背景的橙色,当然,任何其他被标注为 fancy 的元素也不会受这条规则的影响。这都是由于我们书写这条规则的方式,这个效果被限制于被标注为 fancy 的表格单元(即使用 td 元素来选择 fancy 类)。 可以为拥有指定属性的 HTML 元素设置样式,而不仅限于 class 和 id 属性。 注释:只有在规定了 !DOCTYPE 时,IE7 和 IE8 才支持属性选择器。在 IE6 及更低的版本中,不支持属性选择。 下面的例子为带有 title 属性的所有元素设置样式: 亲自试一试 下面的例子为 title="W3School" 的所有元素设置样式: 亲自试一试 下面的例子为包含指定值的 title 属性的所有元素设置样式。适用于由空格分隔的属性值: 亲自试一试 下面的例子为带有包含指定值的 lang 属性的所有元素设置样式。适用于由连字符分隔的属性值: 亲自试一试 属性选择器在为不带有 class 或 id 的表单设置样式时特别有用: 亲自试一试 当读到一个样式表时,浏览器会根据它来格式化 HTML 文档。插入样式表的方法有三种: 当样式需要应用于很多页面时,外部样式表将是理想的选择。在使用外部样式表的情况下,你可以通过改变一个文件来改变整个站点的外观。每个页面使用 标签链接到样式表。 标签在(文档的)头部: 浏览器会从文件 mystyle.css 中读到样式声明,并根据它来格式文档。 外部样式表可以在任何文本编辑器中进行编辑。文件不能包含任何的 html 标签。样式表应该以 .css 扩展名进行保存。下面是一个样式表文件的例子: 不要在属性值与单位之间留有空格。假如你使用 “margin-left: 20 px” 而不是 “margin-left: 20px” ,它仅在 IE 6 中有效,但是在 Mozilla/Firefox 或 Netscape 中却无法正常工作。 当单个文档需要特殊的样式时,就应该使用内部样式表。你可以使用
由于要将表现和内容混杂在一起,内联样式会损失掉样式表的许多优势。请慎用这种方法,例如当样式仅需要在一个元素上应用一次时。 要使用内联样式,你需要在相关的标签内使用样式(style)属性。Style 属性可以包含任何 CSS 属性。本例展示如何改变段落的颜色和左外边距: style="color: sienna; margin-left: 20px">
This is a paragraph
如果某些属性在不同的样式表中被同样的选择器定义,那么属性值将从更具体的样式表中被继承过来。 例如,外部样式表拥有针对 h3 选择器的三个属性: 而内部样式表拥有针对 h3 选择器的两个属性: 假如拥有内部样式表的这个页面同时与外部样式表链接,那么 h3 得到的样式是: 即颜色属性将被继承于外部样式表,而文字排列(text-alignment)和字体尺寸(font-size)会被内部样式表中的规则取代。 CSS 允许应用纯色作为背景,也允许使用背景图像创建相当复杂的效果。 CSS 在这方面的能力远远在 HTML 之上。 可以使用 background-color 属性为元素设置背景色。这个属性接受任何合法的颜色值。 这条规则把元素的背景设置为灰色: 如果您希望背景色从元素中的文本向外少有延伸,只需增加一些内边距: 如需查看本例的效果,可以亲自试一试! 可以为所有元素设置背景色,这包括 body 一直到 em 和 a 等行内元素。 background-color 不能继承,其默认值是 transparent。transparent 有“透明”之意。也就是说,如果一个元素没有指定背景色,那么背景就是透明的,这样其祖先元素的背景才能可见。 要把图像放入背景,需要使用 background-image 属性。background-image 属性的默认值是 none,表示背景上没有放置任何图像。 如果需要设置一个背景图像,必须为这个属性设置一个 URL 值: 大多数背景都应用到 body 元素,不过并不仅限于此。 下面例子为一个段落应用了一个背景,而不会对文档的其他部分应用背景: 您甚至可以为行内元素设置背景图像,下面的例子为一个链接设置了背景图像: 如需查看上述例子的效果,可以亲自试一试! 理论上讲,甚至可以向 textareas 和 select 等替换元素的背景应用图像,不过并不是所有用户代理都能很好地处理这种情况。 另外还要补充一点,background-image 也不能继承。事实上,所有背景属性都不能继承。 如果需要在页面上对背景图像进行平铺,可以使用 background-repeat 属性。 属性值 repeat 导致图像在水平垂直方向上都平铺,就像以往背景图像的通常做法一样。repeat-x 和 repeat-y 分别导致图像只在水平或垂直方向上重复,no-repeat 则不允许图像在任何方向上平铺。 默认地,背景图像将从一个元素的左上角开始。请看下面的例子: 如需查看上例的效果,可以亲自试一试。 可以利用 background-position 属性改变图像在背景中的位置。 下面的例子在 body 元素中将一个背景图像居中放置: 为 background-position 属性提供值有很多方法。首先,可以使用一些关键字:top、bottom、left、right 和 center。通常,这些关键字会成对出现,不过也不总是这样。还可以使用长度值,如 100px 或 5cm,最后也可以使用百分数值。不同类型的值对于背景图像的放置稍有差异。 图像放置关键字最容易理解,其作用如其名称所表明的。例如,top right 使图像放置在元素内边距区的右上角。 根据规范,位置关键字可以按任何顺序出现,只要保证不超过两个关键字 - 一个对应水平方向,另一个对应垂直方向。 如果只出现一个关键字,则认为另一个关键字是 center。 所以,如果希望每个段落的中部上方出现一个图像,只需声明如下: 下面是等价的位置关键字: 百分数值的表现方式更为复杂。假设你希望用百分数值将图像在其元素中居中,这很容易: 这会导致图像适当放置,其中心与其元素的中心对齐。换句话说,百分数值同时应用于元素和图像。也就是说,图像中描述为 50% 50% 的点(中心点)与元素中描述为 50% 50% 的点(中心点)对齐。 如果图像位于 0% 0%,其左上角将放在元素内边距区的左上角。如果图像位置是 100% 100%,会使图像的右下角放在右边距的右下角。 因此,如果你想把一个图像放在水平方向 2/3、垂直方向 1/3 处,可以这样声明: 如果只提供一个百分数值,所提供的这个值将用作水平值,垂直值将假设为 50%。这一点与关键字类似。 background-position 的默认值是 0% 0%,在功能上相当于 top left。这就解释了背景图像为什么总是从元素内边距区的左上角开始平铺,除非您设置了不同的位置值。 长度值解释的是元素内边距区左上角的偏移。偏移点是图像的左上角。 比如,如果设置值为 50px 100px,图像的左上角将在元素内边距区左上角向右 50 像素、向下 100 像素的位置上: 注意,这一点与百分数值不同,因为偏移只是从一个左上角到另一个左上角。也就是说,图像的左上角与 background-position 声明中的指定的点对齐。 如果文档比较长,那么当文档向下滚动时,背景图像也会随之滚动。当文档滚动到超过图像的位置时,图像就会消失。 您可以通过 background-attachment 属性防止这种滚动。通过这个属性,可以声明图像相对于可视区是固定的(fixed),因此不会受到滚动的影响: 如需查看上例的效果,可以亲自试一试。 background-attachment 属性的默认值是 scroll,也就是说,在默认的情况下,背景会随文档滚动。 设置背景颜色 本例演示如何为元素设置背景颜色。 设置文本的背景颜色 本例颜色如何设置部分文本的背景颜色。 将图像设置为背景 本例演示如何将图像设置为背景。 将图像设置为背景 2 本例演示如何为多个元素同时设置背景图像。 如何重复背景图像 本例演示如何重复背景图像。 如何在垂直方向重复背景图像 本例演示如何垂直地重复背景图像。 如何在水平方向重复背景图像 本例演示如何水平地重复背景图像。 如何仅显示一次背景图像 本例演示如何仅显示一次背景图像。 如何放置背景图像 本例演示如何在页面上放置背景图像。 如何使用%来定位背景图像 本例演示如何使用百分比来在页面上定位背景图像。 如何使用像素来定位背景图像 本例演示如何使用像素来在页面上定位背景图像。 如何设置固定的背景图像 本例演示如何设置固定的背景图像。图像不会随着页面的其他部分滚动。 所有背景属性在一个声明之中 本例演示如何使用简写属性来将所有背景属性设置在一个声明之中。 CSS 文本属性可定义文本的外观。 通过文本属性,您可以改变文本的颜色、字符间距,对齐文本,装饰文本,对文本进行缩进,等等。 把 Web 页面上的段落的第一行缩进,这是一种最常用的文本格式化效果。 CSS 提供了 text-indent 属性,该属性可以方便地实现文本缩进。 通过使用 text-indent 属性,所有元素的第一行都可以缩进一个给定的长度,甚至该长度可以是负值。 这个属性最常见的用途是将段落的首行缩进,下面的规则会使所有段落的首行缩进 5 em: 注意:一般来说,可以为所有块级元素应用 text-indent,但无法将该属性应用于行内元素,图像之类的替换元素上也无法应用 text-indent 属性。不过,如果一个块级元素(比如段落)的首行中有一个图像,它会随该行的其余文本移动。 提示:如果想把一个行内元素的第一行“缩进”,可以用左内边距或外边距创造这种效果。 text-indent 还可以设置为负值。利用这种技术,可以实现很多有趣的效果,比如“悬挂缩进”,即第一行悬挂在元素中余下部分的左边: 不过在为 text-indent 设置负值时要当心,如果对一个段落设置了负值,那么首行的某些文本可能会超出浏览器窗口的左边界。为了避免出现这种显示问题,建议针对负缩进再设置一个外边距或一些内边距: text-indent 可以使用所有长度单位,包括百分比值。 百分数要相对于缩进元素父元素的宽度。换句话说,如果将缩进值设置为 20%,所影响元素的第一行会缩进其父元素宽度的 20%。 在下例中,缩进值是父元素的 20%,即 100 个像素: this is a paragragh text-indent 属性可以继承,请考虑如下标记: this is a paragragh. 以上标记中的段落也会缩进 50 像素,这是因为这个段落继承了 id 为 inner 的 div 元素的缩进值。 text-align 是一个基本的属性,它会影响一个元素中的文本行互相之间的对齐方式。它的前 3 个值相当直接,不过第 4 个和第 5 个则略有些复杂。 值 left、right 和 center 会导致元素中的文本分别左对齐、右对齐和居中。 西方语言都是从左向右读,所有 text-align 的默认值是 left。文本在左边界对齐,右边界呈锯齿状(称为“从左到右”文本)。对于希伯来语和阿拉伯语之类的的语言,text-align 则默认为 right,因为这些语言从右向左读。不出所料,center 会使每个文本行在元素中居中。 提示:将块级元素或表元素居中,要通过在这些元素上适当地设置左、右外边距来实现。 您可能会认为 text-align:center 与 最后一个水平对齐属性是 justify。 在两端对齐文本中,文本行的左右两端都放在父元素的内边界上。然后,调整单词和字母间的间隔,使各行的长度恰好相等。您也许已经注意到了,两端对齐文本在打印领域很常见。 需要注意的是,要由用户代理(而不是 CSS)来确定两端对齐文本如何拉伸,以填满父元素左右边界之间的空间。如需了解详情,请参阅 CSS text-align 属性参考页。 word-spacing 属性可以改变字(单词)之间的标准间隔。其默认值 normal 与设置值为 0 是一样的。 word-spacing 属性接受一个正长度值或负长度值。如果提供一个正长度值,那么字之间的间隔就会增加。为 word-spacing 设置一个负值,会把它拉近:
This is a paragraph. The spaces between words will be increased.
This is a paragraph. The spaces between words will be decreased.
实例 TIY :增加或减少单词间距(字间隔) 注释:如需深入理解 CSS 对“字”(word)的定义,请访问 CSS word-spacing 属性参考页。 letter-spacing 属性与 word-spacing 的区别在于,字母间隔修改的是字符或字母之间的间隔。 与 word-spacing 属性一样,letter-spacing 属性的可取值包括所有长度。默认关键字是 normal(这与 letter-spacing:0 相同)。输入的长度值会使字母之间的间隔增加或减少指定的量: 实例 TIY :规定字符间距(字母间隔) text-transform 属性处理文本的大小写。这个属性有 4 个值: 默认值 none 对文本不做任何改动,将使用源文档中的原有大小写。顾名思义,uppercase 和 lowercase 将文本转换为全大写和全小写字符。最后,capitalize 只对每个单词的首字母大写。 作为一个属性,text-transform 可能无关紧要,不过如果您突然决定把所有 h1 元素变为大写,这个属性就很有用。不必单独地修改所有 h1 元素的内容,只需使用 text-transform 为你完成这个修改: 使用 text-transform 有两方面的好处。首先,只需写一个简单的规则来完成这个修改,而无需修改 h1 元素本身。其次,如果您以后决定将所有大小写再切换为原来的大小写,可以更容易地完成修改。 实例 TIY :控制文本中字母的大小写 接下来,我们讨论 text-decoration 属性,这是一个很有意思的属性,它提供了很多非常有趣的行为。 text-decoration 有 5 个值: 不出所料,underline 会对元素加下划线,就像 HTML 中的 U 元素一样。overline 的作用恰好相反,会在文本的顶端画一个上划线。值 line-through 则在文本中间画一个贯穿线,等价于 HTML 中的 S 和 strike 元素。blink 会让文本闪烁,类似于 Netscape 支持的颇招非议的 blink 标记。 none 值会关闭原本应用到一个元素上的所有装饰。通常,无装饰的文本是默认外观,但也不总是这样。例如,链接默认地会有下划线。如果您希望去掉超链接的下划线,可以使用以下 CSS 来做到这一点: 注意:如果显式地用这样一个规则去掉链接的下划线,那么锚与正常文本之间在视觉上的唯一差别就是颜色(至少默认是这样的,不过也不能完全保证其颜色肯定有区别)。 还可以在一个规则中结合多种装饰。如果希望所有超链接既有下划线,又有上划线,则规则如下: 不过要注意的是,如果两个不同的装饰都与同一元素匹配,胜出规则的值会完全取代另一个值。请考虑以下的规则: 对于给定的规则,所有 class 为 stricken 的 h2 元素都只有一个贯穿线装饰,而没有下划线和上划线,因为 text-decoration 值会替换而不是累积起来。 white-space 属性会影响到用户代理对源文档中的空格、换行和 tab 字符的处理。 通过使用该属性,可以影响浏览器处理字之间和文本行之间的空白符的方式。从某种程度上讲,默认的 XHTML 处理已经完成了空白符处理:它会把所有空白符合并为一个空格。所以给定以下标记,它在 Web 浏览器中显示时,各个字之间只会显示一个空格,同时忽略元素中的换行: This paragraph has many
spaces in it. 可以用以下声明显式地设置这种默认行为: 上面的规则告诉浏览器按照平常的做法去处理:丢掉多余的空白符。如果给定这个值,换行字符(回车)会转换为空格,一行中多个空格的序列也会转换为一个空格。 实例 TIY :white-space: normal 不过,如果将 white-space 设置为 pre,受这个属性影响的元素中,空白符的处理就有所不同,其行为就像 XHTML 的 pre 元素一样;空白符不会被忽略。 如果 white-space 属性的值为 pre,浏览器将会注意额外的空格,甚至回车。在这个方面,而且仅在这个方面,任何元素都可以相当于一个 pre 元素。 实例 TIY :white-space: pre 注意:经测试,IE 7 以及更早版本的浏览器不支持该值,因此请使用非 IE 的浏览器来查看上面的实例。 与之相对的值是 nowrap,它会防止元素中的文本换行,除非使用了一个 br 元素。在 CSS 中使用 nowrap 非常类似于 HTML 4 中用 实例 TIY :white-space: nowrap 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 属性的行为: 如果您阅读的是英文书籍,就会从左到右、从上到下地阅读,这就是英文的流方向。不过,并不是所有语言都如此。我们知道古汉语就是从右到左来阅读的,当然还包括希伯来语和阿拉伯语等等。CSS2 引入了一个属性来描述其方向性。 direction 属性影响块级元素中文本的书写方向、表中列布局的方向、内容水平填充其元素框的方向、以及两端对齐元素中最后一行的位置。 注释:对于行内元素,只有当 unicode-bidi 属性设置为 embed 或 bidi-override 时才会应用 direction 属性。 direction 属性有两个值:ltr 和 rtl。大多数情况下,默认值是 ltr,显示从左到右的文本。如果显示从右到左的文本,应使用值 rtl。 设置文本颜色 本例演示如何设置文本的颜色。 设置文本的背景颜色 本例颜色如何设置部分文本的背景颜色。 规定字符间距 本例演示如何增加或减少字符间距。 使用百分比设置行间距 本例演示如何使用百分比值来设置段落中的行间距。 使用像素值设置行间距 本例演示如何使用像素值来设置段落中的行间距。 使用数值来设置行间距 本例演示如何使用一个数值来设置段落中的行间距。 对齐文本 本例演示如何对齐文本。 修饰文本 本例演示如何向文本添加修饰。 缩进文本 本例演示如何缩进文本首行。 控制文本中的字母 本例演示如何控制文本中的字母。 在元素中禁止文本折行 本例演示如何禁止在元素中的文本折行。 增加单词间距 本例演示如何增加段落中单词间的距离。 CSS 字体属性定义文本的字体系列、大小、加粗、风格(如斜体)和变形(如小型大写字母)。 在 CSS 中,有两种不同类型的字体系列名称: 除了各种特定的字体系列外,CSS 定义了 5 种通用字体系列: 如果需要了解更多有关字体系列的知识,请阅读 CSS 字体系列。 使用 font-family 属性 定义文本的字体系列。 如果你希望文档使用一种 sans-serif 字体,但是你并不关心是哪一种字体,以下就是一个合适的声明: 亲自试一试 这样用户代理就会从 sans-serif 字体系列中选择一个字体(如 Helvetica),并将其应用到 body 元素。因为有继承,这种字体选择还将应用到 body 元素中包含的所有元素,除非有一种更特定的选择器将其覆盖。 除了使用通用的字体系列,您还可以通过 font-family 属性设置更具体的字体。 下面的例子为所有 h1 元素设置了 Georgia 字体: 亲自试一试 这样的规则同时会产生另外一个问题,如果用户代理上没有安装 Georgia 字体,就只能使用用户代理的默认字体来显示 h1 元素。 我们可以通过结合特定字体名和通用字体系列来解决这个问题: 亲自试一试 如果读者没有安装 Georgia,但安装了 Times 字体(serif 字体系列中的一种字体),用户代理就可能对 h1 元素使用 Times。尽管 Times 与 Georgia 并不完全匹配,但至少足够接近。 因此,我们建议在所有 font-family 规则中都提供一个通用字体系列。这样就提供了一条后路,在用户代理无法提供与规则匹配的特定字体时,就可以选择一个候选字体。 如果您对字体非常熟悉,也可以为给定的元素指定一系列类似的字体。要做到这一点,需要把这些字体按照优先顺序排列,然后用逗号进行连接: 亲自试一试 根据这个列表,用户代理会按所列的顺序查找这些字体。如果列出的所有字体都不可用,就会简单地选择一种可用的 serif 字体。 您也许已经注意到了,上面的例子中使用了单引号。只有当字体名中有一个或多个空格(比如 New York),或者如果字体名包括 # 或 $ 之类的符号,才需要在 font-family 声明中加引号。 单引号或双引号都可以接受。但是,如果把一个 font-family 属性放在 HTML 的 style 属性中,则需要使用该属性本身未使用的那种引号: ... 亲自试一试 font-style 属性最常用于规定斜体文本。 该属性有三个值: 亲自试一试 font-style 非常简单:用于在 normal 文本、italic 文本和 oblique 文本之间选择。唯一有点复杂的是明确 italic 文本和 oblique 文本之间的差别。 斜体(italic)是一种简单的字体风格,对每个字母的结构有一些小改动,来反映变化的外观。与此不同,倾斜(oblique)文本则是正常竖直文本的一个倾斜版本。 通常情况下,italic 和 oblique 文本在 web 浏览器中看上去完全一样。 font-variant 属性可以设定小型大写字母。 小型大写字母不是一般的大写字母,也不是小写字母,这种字母采用不同大小的大写字母。 亲自试一试 font-weight 属性设置文本的粗细。 使用 bold 关键字可以将文本设置为粗体。 关键字 100 ~ 900 为字体指定了 9 级加粗度。如果一个字体内置了这些加粗级别,那么这些数字就直接映射到预定义的级别,100 对应最细的字体变形,900 对应最粗的字体变形。数字 400 等价于 normal,而 700 等价于 bold。 如果将元素的加粗设置为 bolder,浏览器会设置比所继承值更粗的一个字体加粗。与此相反,关键词 lighter 会导致浏览器将加粗度下移而不是上移。 亲自试一试 font-size 属性设置文本的大小。 有能力管理文本的大小在 web 设计领域很重要。但是,您不应当通过调整文本大小使段落看上去像标题,或者使标题看上去像段落。 请始终使用正确的 HTML 标题,比如使用 来标记段落。 font-size 值可以是绝对或相对值。 绝对值: 相对大小: 注意:如果您没有规定字体大小,普通文本(比如段落)的默认大小是 16 像素 (16px=1em)。 通过像素设置文本大小,可以对文本大小进行完全控制: 实例 亲自试一试 在 Firefox, Chrome, and Safari 中,可以重新调整以上例子的文本大小,但是在 Internet Explorer 中不行。 虽然可以通过浏览器的缩放工具调整文本大小,但是这实际上是对整个页面的调整,而不仅限于文本。 如果要避免在 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) 实例 亲自试一试 在上面的例子中,以 em 为单位的文本大小与前一个例子中以像素计的文本是相同的。不过,如果使用 em 单位,则可以在所有浏览器中调整文本大小。 不幸的是,在 IE 中仍存在问题。在重设文本大小时,会比正常的尺寸更大或更小。 在所有浏览器中均有效的方案是为 body 元素(父元素)以百分比设置默认的 font-size 值: 实例 亲自试一试 我们的代码非常有效。在所有浏览器中,可以显示相同的文本大小,并允许所有浏览器缩放文本的大小。 设置文本的字体 本例演示如何设置文本字体。 设置字体尺寸 本例演示如何设置字体尺寸。 设置字体风格 本例演示如何设置字体风格。 设置字体的异体 本例演示如何设置字体的异体。 设置字体的粗细 本例演示如何设置字体的粗细。 所有字体属性在一个声明之内 本例演示如何使用简写属性将字体属性设置在一个声明之内。 我们能够以不同的方法为链接设置样式。 能够设置链接样式的 CSS 属性有很多种(例如 color, font-family, background 等等)。 链接的特殊性在于能够根据它们所处的状态来设置它们的样式。 链接的四种状态: 亲自试一试 当为链接的不同状态设置样式时,请按照以下次序规则: 在上面的例子中,链接根据其状态改变颜色。 让我们看看其他几种常见的设置链接样式的方法: text-decoration 属性大多用于去掉链接中的下划线: 实例 亲自试一试 background-color 属性规定链接的背景色: 实例 亲自试一试 向链接添加不同的样式 本例演示如何向链接添加其他样式。 高级 - 创建链接框 本例演示了更高级的示例,我们结合了若干种 CSS 属性,来把链接显示为方框。 CSS 列表属性允许你放置、改变列表项标志,或者将图像作为列表项标志。 从某种意义上讲,不是描述性的文本的任何内容都可以认为是列表。人口普查、太阳系、家谱、参观菜单,甚至你的所有朋友都可以表示为一个列表或者是列表的列表。 由于列表如此多样,这使得列表相当重要,所以说,CSS 中列表样式不太丰富确实是一大憾事。 要影响列表的样式,最简单(同时支持最充分)的办法就是改变其标志类型。 例如,在一个无序列表中,列表项的标志 (marker) 是出现在各列表项旁边的圆点。在有序列表中,标志可能是字母、数字或另外某种计数体系中的一个符号。 要修改用于列表项的标志类型,可以使用属性 list-style-type: 上面的声明把无序列表中的列表项标志设置为方块。 有时,常规的标志是不够的。你可能想对各标志使用一个图像,这可以利用 list-style-image 属性做到: 只需要简单地使用一个 url() 值,就可以使用图像作为标志。 CSS2.1 可以确定标志出现在列表项内容之外还是内容内部。这是利用 list-style-position 完成的。 为简单起见,可以将以上 3 个列表样式属性合并为一个方便的属性:list-style,就像这样: list-style 的值可以按任何顺序列出,而且这些值都可以忽略。只要提供了一个值,其它的就会填入其默认值。 在无序列表中的不同类型的列表标记 本例演示在CSS中不同类型的列表项标记。 在有序列表中不同类型的列表项标记 本例演示在CSS中不同类型的列表项标记。 所有的列表样式类型 本例演示在CSS中所有不同类型的列表项标记。 将图像作为列表项标记 本例演示如何将图像作为列表项标记。 放置列表标记 本例演示在何处放置列表标记。 在一个声明中定义所有的列表属性 本例演示将所有针对列表的属性设置于一个简写属性。 CSS 表格属性可以帮助您极大地改善表格的外观。 如需在 CSS 中设置表格边框,请使用 border 属性。 下面的例子为 table、th 以及 td 设置了蓝色边框: 亲自试一试 请注意,上例中的表格具有双线条边框。这是由于 table、th 以及 td 元素都有独立的边框。 如果需要把表格显示为单线条边框,请使用 border-collapse 属性。 border-collapse 属性设置是否将表格边框折叠为单一边框: 亲自试一试 通过 width 和 height 属性定义表格的宽度和高度。 下面的例子将表格宽度设置为 100%,同时将 th 元素的高度设置为 50px: 亲自试一试 text-align 和 vertical-align 属性设置表格中文本的对齐方式。 text-align 属性设置水平对齐方式,比如左对齐、右对齐或者居中: 亲自试一试 vertical-align 属性设置垂直对齐方式,比如顶部对齐、底部对齐或居中对齐: 亲自试一试 如需控制表格中内容与边框的距离,请为 td 和 th 元素设置 padding 属性: 亲自试一试 下面的例子设置边框的颜色,以及 th 元素的文本和背景颜色: 亲自试一试 制作一个漂亮的表格 本例演示如何创造一个漂亮的表格。 显示表格中的空单元 本例演示是否显示表格中的空单元。 设置表格边框之间的空白 本例演示如何设置单元格边框之间的距离。 设置表格标题的位置 本例演示如何定位表格的标题。 一个选择器,多种用法
#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;
}
单独的选择器
#sidebar
{
border: 1px dotted #000;
padding: 10px;
}div#sidebar
{
border: 1px dotted #000;
padding: 10px;
}
.center
{text-align: center}class="center">
This heading will be center-aligned
.fancy td
{
color: #f60;
background: #666;
}
td.fancy
{
color: #f60;
background: #666;
}
class="fancy">
对带有指定属性的 HTML 元素设置样式。
属性选择器
[title]
{
color:red;
}
属性和值选择器
[title=W3School]
{
border:5px solid blue;
}
属性和值选择器 - 多个值
[title~=hello]
{ color:red; }[lang|=en] { color:red; }
设置表单的样式
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]
匹配属性值中包含指定值的每个元素。
如何插入样式表
外部样式表
<
link
rel="stylesheet" type="text/css" href="mystyle.css
" />
hr {color: sienna;}
p {margin-left: 20px;}
body {background-image: url("images/back40.gif");}
内部样式表
内联样式
多重样式
h3 {
color: red;
text-align:
left
;
font-size: 8pt
;
}h3 {
text-align:
right
;
font-size: 20pt
;
}color:
red
;
text-align: right
;
font-size: 20pt
;背景色
p {background-color: gray;}
p {background-color: gray; padding: 20px;}
背景图像
body {background-image: url(/i/eg_bg_04.gif);}
p.flower {background-image: url(/i/eg_bg_03.gif);}
a.radio {background-image: url(/i/eg_bg_07.gif);}
背景重复
body
{
background-image: url(/i/eg_bg_03.gif);
background-repeat: repeat-y;
}
背景定位
body
{
background-image:url('/i/eg_bg_03.gif');
background-repeat:no-repeat;
background-position:center;
}
关键字
p
{
background-image:url('bgimg.gif');
background-repeat:no-repeat;
background-position:top;
}
单一关键字
等价的关键字
center
center center
top
top center 或 center top
bottom
bottom center 或 center bottom
right
right center 或 center right
left
left center 或 center left
百分数值
body
{
background-image:url('/i/eg_bg_03.gif');
background-repeat:no-repeat;
background-position:50% 50%;
}
body
{
background-image:url('/i/eg_bg_03.gif');
background-repeat:no-repeat;
background-position:66% 33%;
}
长度值
body
{
background-image:url('/i/eg_bg_03.gif');
background-repeat:no-repeat;
background-position:50px 100px;
}
背景关联
body
{
background-image:url(/i/eg_bg_02.gif);
background-repeat:no-repeat;
background-attachment:fixed
}
CSS 背景实例
CSS 背景属性
属性
描述
background
简写属性,作用是将背景属性设置在一个声明中。
background-attachment
背景图像是否固定或者随着页面的其余部分滚动。
background-color
设置元素的背景颜色。
background-image
把图像设置为背景。
background-position
设置背景图像的起始位置。
background-repeat
设置背景图像是否及如何重复。
缩进文本
p {text-indent: 5em;}
使用负值
p {text-indent: -5em;}
p {text-indent: -5em; padding-left: 5em;}
使用百分比值
div {width: 500px;}
p {text-indent: 20%;}
继承
div#outer {width: 500px;}
div#inner {text-indent: 10%;}
p {width: 200px;}
水平对齐
text-align:center 与
justify
字间隔
p.spread {word-spacing: 30px;}
p.tight {word-spacing: -0.5em;}
字母间隔
h1 {letter-spacing: -0.5em}
h4 {letter-spacing: 20px}
This is header 1
This is header 4
字符转换
h1 {text-transform: uppercase}
文本装饰
a {text-decoration: none;}
a:link a:visited {text-decoration: underline overline;}
h2.stricken {text-decoration: line-through;}
h2 {text-decoration: underline overline;}
处理空白符
p {white-space: normal;}
值 pre
值 nowrap
将一个表单元格设置为不能换行,不过 white-space 值可以应用到任何元素。
值 pre-wrap 和 pre-line
总结
值
空白符
换行符
自动换行
pre-line
合并
保留
允许
normal
合并
忽略
允许
nowrap
合并
忽略
不允许
pre
保留
保留
不允许
pre-wrap
保留
保留
允许
文本方向
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 字体系列
指定字体系列
使用通用字体系列
body {font-family: sans-serif;}
指定字体系列
h1 {font-family: Georgia;}
h1 {font-family: Georgia,
serif
;}p {font-family: Times, TimesNR, 'New Century Schoolbook',
Georgia, 'New York', serif;}
使用引号
字体风格
实例
p.normal {font-style:normal;}
p.italic {font-style:italic;}
p.oblique {font-style:oblique;}
italic 和 oblique 的区别
字体变形
实例
p {font-variant:small-caps;}
字体加粗
实例
p.normal {font-weight:normal;}
p.thick {font-weight:bold;}
p.thicker {font-weight:900;}
字体大小
-
来标记标题,使用
使用像素来设置字体大小
h1 {font-size:60px;}
h2 {font-size:40px;}
p {font-size:14px;}
使用 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
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
设置字体的粗细。
设置链接的样式
实例
a:link {color:#FF0000;} /* 未被访问的链接 */
a:visited {color:#00FF00;} /* 已被访问的链接 */
a:hover {color:#FF00FF;} /* 鼠标指针移动到链接上 */
a:active {color:#0000FF;} /* 正在被点击的链接 */
常见的链接样式
文本修饰
a:link {text-decoration:none;}
a:visited {text-decoration:none;}
a:hover {text-decoration:underline;}
a:active {text-decoration:underline;}
背景色
a:link {background-color:#B2FF99;}
a:visited {background-color:#FFFF85;}
a:hover {background-color:#FF704D;}
a:active {background-color:#FF704D;}
更多实例
CSS 列表
列表类型
ul {list-style-type : square}
列表项图像
ul li {list-style-image : url(xxx.gif)}
列表标志位置
简写列表样式
li {list-style : url(example.gif) square inside}
CSS 列表实例:
CSS 列表属性(list)
属性
描述
list-style
简写属性。用于把所有用于列表的属性设置于一个声明中。
list-style-image
将图象设置为列表项标志。
list-style-position
设置列表中列表项标志的位置。
list-style-type
设置列表项标志的类型。
marker-offset
表格边框
table, th, td
{
border: 1px solid blue;
}
折叠边框
table
{
border-collapse:collapse;
}
table,th, td
{
border: 1px solid black;
}
表格宽度和高度
table
{
width:100%;
}
th
{
height:50px;
}
表格文本对齐
td
{
text-align:right;
}
td
{
height:50px;
vertical-align:bottom;
}
表格内边距
td
{
padding:15px;
}
表格颜色
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
设置显示单元、行和列的算法。
亲自试一试 - 更多实例
你可能感兴趣的:(Qt相关)