• css 初步学习笔记


    一。CSS 基础语法     层叠样式表(Cascading Style Sheets)
    CSS 规则由两个主要的部分构成:选择器selector,以及一条或多条声明。
    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;}
    1.1值的不同写法和单位
    除了英文单词 red,我们还可以使用十六进制的颜色值 #ff0000:
    p { color: #ff0000; }为了节约字节,我们可以使用 CSS 的缩写形式:
    p { color: #f00; }我们还可以通过两种方法使用 RGB 值:
    p { color: #ff0000; }
    p { color: rgb(100%,0%,0%); }
    1.2记得写引号
    提示:如果值为若干单词,则要给值加引号:
    p {font-family: "sans serif";}
    1.3多重声明:
    提示:如果要定义不止一个声明,则需要用分号将每个声明分开。下面的例子展示出如何定义一个红色文字的居中段落。最后一条规则是不需要加分号的,因为分号在英语中是一个分隔符号,不是结束符号。然而,大多数有经验的设计师会在每条声明的末尾都加上分号,这么做的好处是,当你从现有的规则中增减声明时,会尽可能地减少出错的可能性。就像这样:
    p {text-align:center; color:red;} 你应该在每行只描述一个属性,这样可以增强样式定义的可读性,就像这样:
    p {
      text-align: center;
      color: black;
      font-family: arial;
    }
    1.4空格和大小写
    大多数样式表包含不止一条规则,而大多数规则包含不止一个声明。多重声明和空格的使用使得样式表更容易被编辑:

    body {
      color: #000;
      background: #fff;
      margin: 0;
      padding: 0;
      font-family: Georgia, Palatino, serif;
      }是否包含空格不会影响 CSS 在浏览器的工作效果,同样,与 XHTML 不同,CSS 对大小写不敏感。不过存在一个例外:如果涉及到与 HTML 文档一起工作的话,class 和 id 名称对大小写是敏感的。

    2.css的高级语法
    2.1选择器的分组
    用逗号将需要分组的选择器分开。我们对所有的标题元素进行了分组。所有的标题元素都是绿色的。
    h1,h2,h3,h4,h5,h6 {
      color: green;
      }
    2.2继承及其问题
    根据 CSS,子元素从父元素继承属性。但是它并不总是按此方式工作。看看下面这条规则:
    body {
         font-family: Verdana, sans-serif;
         }根据上面这条规则,站点的 body 元素将使用 Verdana 字体(假如访问者的系统中存在该字体的话)。
    通过 CSS 继承,子元素将继承最高级元素(在本例中是 body)所拥有的属性(这些子元素诸如 p, td, ul, ol, ul, li, dl, dt,和 dd)。不需要另外的规则,所有 body 的子元素都应该显示 Verdana 字体,子元素的子元素也一样。并且在大部分的现代浏览器中,也确实是这样的。

    2.3友善地对待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;
         }
    2.3.继承是一个诅咒吗?
    如果你不希望 "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;
         }
    3.派生选择器
    通过依据元素在其位置的上下文关系来定义样式,你可以使标记更加简洁。
    在 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>

    总结:函数:font-family属性、sans-serif非衬线体、Verdana字体、strong 粗体强调 font-weight字体粗细 bold粗体 font-style字体风格    normal普通、正常
    4. css id选择器
    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 文档中出现一次。
    4.2。id 选择器和派生选择器    text-align水平对齐 、margin-top上边距属性
    在现代布局中,id 选择器常常用于建立派生选择器。
    #sidebar p {
     font-style: italic;
     text-align: right;
     margin-top: 0.5em;
     }
    上面的样式只会应用于出现在 id 是 sidebar 的元素内的段落。这个元素很可能是 div 或者是表格单元,尽管它也可能是一个表格或者其他块级元素。它甚至可以是一个内联元素,比如 <em></em> 或者 <span></span>,不过这样的用法是非法的,因为不可以在内联元素 <span> 中嵌入 <p> (如果你忘记了原因
    #sidebar h2 {
     font-size: 1em;
     font-weight: normal;
     font-style: italic;
     margin: 0;
     line-height: 1.5;
    4.3单独的选择器
    id 选择器即使不被用来创建派生选择器,它也可以独立发挥作用:

    #sidebar {
     border: 1px dotted #000;
     padding: 10px;
     }
    5.CSS 类选择器
    CSS 中,类选择器以一个点号显示:
    .center {text-align: center}
     text-align: right;
    上面的例子,所有拥有 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 中起作用。
    4.4.和 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 类)。
     }
    在这里,与页面中的其他 p 元素明显不同的是,sidebar 内的 p 元素得到了特殊的处理,同时,与页面中其他所有 h2 元素明显不同的是,sidebar 中的 h2 元素也得到了不同的特殊处理。
    5.css属性选择器
    下面的例子为带有 title 属性的所有元素设置样式:
    <html>
    <head>
    <style type="text/css">
    [title]
    {
    color:red;
    }
    </style>
    </head>
    5.1属性和值选择器
    下面的例子为 title="W3School" 的所有元素设置样式:
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html>
    <head>
    <style type="text/css">
    [title=W3School]
    {
    border:5px solid blue;
    }
    </style>
    </head>

    <body>
    <h1>可以应用样式:</h1>
    <img title="W3School" src="/i/w3school_logo_white.gif" />
    <br />
    <a title="W3School" href="http://w3school.com.cn">W3School</a>
    <hr />

    <h1>无法应用样式:</h1>
    <p title="greeting">Hi!</p>
    <a class="W3School" href="http://w3school.com.cn">W3School</a>
    </body>
    </html>
    5.2属性和值选择器 - 多个值
    下面的例子为包含指定值的 title 属性的所有元素设置样式。适用于由空格分隔的属性值:
    [title~=hello] { color:red; }
    下面的例子为带有包含指定值的 lang 属性的所有元素设置样式。适用于由连字符分隔的属性值:
    [lang|=en] { color:red; }
    5.3设置表单的样式
    属性选择器在为不带有 class 或 id 的表单设置样式时特别有用:
    input[type="text"]
    {
      150px;
      display:block;
      margin-bottom:10px;
      background-color:yellow;
      font-family: Verdana, Arial;
    }
    input[type="button"]
    {
      120px;
      margin-left:35px;
      display:block;
      font-family: Verdana, Arial;
    }
    6.如何插入样式表
    当读到一个样式表时,浏览器会根据它来格式化 HTML 文档。插入样式表的方法有三种:

    6.1外部样式表  
    当样式需要应用于很多页面时,外部样式表将是理想的选择。在使用外部样式表的情况下,你可以通过改变一个文件来改变整个站点的外观。每个页面使用 <link> 标签链接到样式表。<link> 标签在(文档的)头部:
    <head>
    <link rel="stylesheet" type="text/css" href="mystyle.css" />
    </head>
    浏览器会从文件 mystyle.css 中读到样式声明,并根据它来格式文档。
    外部样式表可以在任何文本编辑器中进行编辑。文件不能包含任何的 html 标签。样式表应该以 .css 扩展名进行保存。下面是一个样式表文件的例子:      margin-left左边距
    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 中却无法正常工作。
    6.2内部样式表
    当单个文档需要特殊的样式时,就应该使用内部样式表。你可以使<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>
    6.3多重样式
    如果某些属性在不同的样式表中被同样的选择器定义,那么属性值将从更具体的样式表中被继承过来。
    例如,外部样式表拥有针对 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)会被内部样式表中的规则取代。
    7.css背景
    背景色
    这条规则把元素的背景设置为灰色:
    p {background-color: gray;}如果您希望背景色从元素中的文本向外少有延伸,只需增加一些内边距:
    p {background-color: gray; padding: 20px;}

    <html>
    <head>
    <style type="text/css">
    body {background-color: yellow}
    h1 {background-color: #00ff00}
    h2 {background-color: transparent}
    p {background-color: #fa00ff}
    p.no2 {background-color: gray; padding: 20px;}
    </style>
    </head>
    <body>
    <h1>这是标题 1</h1>
    <h2>这是标题 2</h2>
    <p>这是段落</p>
    <p class="no2">这个段落设置了内边距。</p>
    </body>
    </html>
    可以为所有元素设置背景色,这包括 body 一直到 em 和 a 等行内元素。
    background-color 不能继承,其默认值是 transparent。transparent 有“透明”之意。也就是说,如果一个元素没有指定背景色,那么背景就是透明的,这样其祖先元素的背景才能可见。
    7.1。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);}
    7.2背景重复  background-repeat:背景重复
    属性值 repeat 导致图像在水平垂直方向上都平铺,就像以往背景图像的通常做法一样。repeat-x 和 repeat-y 分别导致图像只在水平或垂直方向上重复,no-repeat 则不允许图像在任何方向上平铺。
    背景图像将从一个元素的左上角开始。请看下面的例子:
    body
      {
      background-image: url(/i/eg_bg_03.gif);
      background-repeat: repeat-y;
      }
    例子:
    <html>
    <head>
    <style type="text/css">
    body
    {
    background-image:
    url(/i/eg_bg_03.gif);
    background-repeat: repeat-y
    }
    </style>
    </head>
    <body>
    </body>
    </html>
    7.3背景定位  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;
      }
    7.3百分数值  background-position背景图片初始位置
    百分数值的表现方式更为复杂。假设你希望用百分数值将图像在其元素中居中,这很容易:
    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%;
      }
    background-position 的默认值是 0% 0%,在功能上相当于 top left。这就解释了背景图像为什么总是从元素内边距区的左上角开始平铺,除非您设置了不同的位置值。
    7.4.长度值
    长度值解释的是元素内边距区左上角的偏移。偏移点是图像的左上角。
    比如,如果设置值为 50px 100px,图像的左上角将在元素内边距区左上角向右 50 像素、向下 100 像素的位置上:
    body
      {
        background-image:url('/i/eg_bg_03.gif');
        background-repeat:no-repeat;
        background-position:50px 100px;
      }
    注意,这一点与百分数值不同,因为偏移只是从一个左上角到另一个左上角。也就是说,图像的左上角与 background-position 声明中的指定的点对齐。
    7.5背景关联   不重复no-repeat
    如果文档比较长,那么当文档向下滚动时,背景图像也会随之滚动。当文档滚动到超过图像的位置时,图像就会消失。
    body
      {
      background-image:url(/i/eg_bg_02.gif);
      background-repeat:no-repeat;
      background-attachment:fixed
      }
    background-attachment 属性的默认值是 scroll,也就是说,在默认的情况下,背景会随文档滚动。
    例子1.设置文本的颜色
    <html>
    <head>
    <style type="text/css">
    span.highlight
    {
    background-color:yellow
    }
    </style>
    </head>
    <body>
    <p>
    <span class="highlight">这是文本。</span> 这是文本。 这是文本
    <span class="highlight">这是文本。</span>
    </p>
    </body>
    </html>
    例子2.将图像设置为背景
    <html>
    <head>
    <style type="text/css">
    body {background-image:url(/i/eg_bg_04.gif);}
    p.flower {background-image: url(/i/eg_bg_03.gif); padding: 20px;}
    a.radio {background-image: url(/i/eg_bg_07.gif);  padding: 20px;}
    </style>
    </head>
    <body>
    <p class="flower">我是一个有花纹背景的段落。<a href="#" class="radio">我是一个有放射性背景的链接。</a></p>
    <p><b>注释:</b>为了清晰地显示出段落和链接的背景图像,我们为它们设置了少许内边距。</p>
    </body>
    </html>
    例子3.如何放置图像
    <html>
    <head>
    <style type="text/css">
    body
    {
      background-image:url('/i/eg_bg_03.gif');
      background-repeat:no-repeat;
      background-attachment:fixed;
      background-position:center;
    }
    </style>
    </head>
    <body>
    <body>
    <p><b>提示:</b>您需要把 background-attachment 属性设置为 "fixed",才能保证该属性在 Firefox 和 Opera 中正常工作。</p>
    </body>
    </body>
    </html>
    总结:
    CSS 背景属性
    属性     描述
    background  简写属性,作用是将背景属性设置在一个声明中。
    background-attachment  背景图像是否固定或者随着页面的其余部分滚动
    background-color  设置元素的背景颜色。
    background-image  把图像设置为背景。
    background-position  设置背景图像的起始位置。
    background-repeat  设置背景图像是否及如何重复。
    8.css文本
    8.1缩进文本
    通过使用 text-indent 属性,所有元素的第一行都可以缩进一个给定的长度,甚至该长度可以是负值。
    这个属性最常见的用途是将段落的首行缩进,下面的规则会使所有段落的首行缩进 5 em:
    p {text-indent: 5em;}
    注意:一般来说,可以为所有块级元素应用 text-indent,但无法将该属性应用于行内元素,图像之类的替换元素上也无法应用 text-indent 属性。不过,如果一个块级元素(比如段落)的首行中有一个图像,它会随该行的其余文本移动。
    提示:如果想把一个行内元素的第一行“缩进”,可以用左内边距或外边距创造这种效果。
    8.2使用负值      text-indent 文本缩进   padding-left左间隙属性
    text-indent 还可以设置为负值。利用这种技术,可以实现很多有趣的效果,比如“悬挂缩进”,即第一行悬挂在元素中余下部分的左边:
    p {text-indent: -5em;}
    不过在为 text-indent 设置负值时要当心,如果对一个段落设置了负值,那么首行的某些文本可能会超出浏览器窗口的左边界。为了避免出现这种显示问题,建议针对负缩进再设置一个外边距或一些内边距:
    p {text-indent: -5em; padding-left: 5em;}
    8.3使用百分比值
    text-indent 可以使用所有长度单位,包括百分比值。
    百分数要相对于缩进元素父元素的宽度。换句话说,如果将缩进值设置为 20%,所影响元素的第一行会缩进其父元素宽度的 20%。
    在下例中,缩进值是父元素的 20%,即 100 个像素:
    div { 500px;}
    p {text-indent: 20%;}
    <div>
    <p>this is a paragragh</p>
    </div>
    8.4继承
    text-indent 属性可以继承,请考虑如下标记:
    div#outer { 500px;}
    div#inner {text-indent: 10%;}
    p { 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 元素的缩进值。
    8.5水平对齐
    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)来确定两端对齐文本如何拉伸,以填满父元素左右边界之间的空间。
    8.6字间隔
    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>

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

    与 word-spacing 属性一样,letter-spacing 属性的可取值包括所有长度。默认关键字是 normal(这与 letter-spacing:0 相同)。输入的长度值会使字母之间的间隔增加或减少指定的量:
    h1 {letter-spacing: -0.5em}
    h4 {letter-spacing: 20px}
    8.8字符转换  text-transform文本转换 
    text-transform 属性处理文本的大小写。这个属性有 4 个值:
    none
    uppercase
    lowercase
    capitalize
    默认值 none 对文本不做任何改动,将使用源文档中的原有大小写。顾名思义,uppercase 和 lowercase 将文本转换为全大写和全小写字符。最后,capitalize 只对每个单词的首字母大写。
    作为一个属性,text-transform 可能无关紧要,不过如果您突然决定把所有 h1 元素变为大写,这个属性就很有用。不必单独地修改所有 h1 元素的内容,只需使用 text-transform 为你完成这个修改:
    h1 {text-transform: uppercase}
    注意:如果显式地用这样一个规则去掉链接的下划线,那么锚与正常文本之间在视觉上的唯一差别就是颜色(至少默认是这样的,不过也不能完全保证其颜色肯定有区别)
    还可以在一个规则中结合多种装饰。如果希望所有超链接既有下划线,又有上划线,则规则如下:
    a:link a:visited {text-decoration: underline overline;}
    不过要注意的是,如果两个不同的装饰都与同一元素匹配,胜出规则的值会完全取代另一个值。请考虑以下的规则:
    h2.stricken {text-decoration: line-through;}
    h2 {text-decoration: underline overline;}
    对于给定的规则,所有 class 为 stricken 的 h2 元素都只有一个贯穿线装饰,而没有下划线和上划线,因为 text-decoration 值会替换而不是累积起来。
    8.9处理空白符
    white-space 属性会影响到用户代理对源文档中的空格、换行和 tab 字符的处理。
    通过使用该属性,可以影响浏览器处理字之间和文本行之间的空白符的方式。从某种程度上讲,默认的 XHTML 处理已经完成了空白符处理:它会把所有空白符合并为一个空格。所以给定以下标记,它在 Web 浏览器中显示时,各个字之间只会显示一个空格,同时忽略元素中的换行:
    <p>This     paragraph has    many
        spaces           in it.</p>
    可以用以下声明显式地设置这种默认行为:
    p {white-space: normal;}
    上面的规则告诉浏览器按照平常的做法去处理:丢掉多余的空白符。如果给定这个值,换行字符(回车)会转换为空格,一行中多个空格的序列也会转换为一个空格。
    实例 TIY :white-space: normal
    <html>
    <head>
    <style type="text/css">
    p {white-space: normal;}
    </style>
    </head>
    <body>
    <p>This     paragraph has    many
        spaces           in it.</p>
    <p>注释:当 white-space 属性设置为 normal 时,会合并所有的空白符,并忽略换行符。</p>
    </body>
    </html>

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

    如果 white-space 属性的值为 pre,浏览器将会注意额外的空格,甚至回车。在这个方面,而且仅在这个方面,任何元素都可以相当于一个 pre 元素。
    TIY :white-space: pre
    <html>
    <head>
    <style type="text/css">
    p {white-space: pre;}
    </style>
    </head>
    <body>
    <p>This     paragraph has    many
        spaces           in it.</p>
    <p>注释:当 white-space 属性设置为 pre 时,浏览器不会合并空白符,也不会忽略换行符。</p>
    </body>
    </html>

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

    值 pre-wrap 和 pre-line
    CSS2.1 引入了值 pre-wrap 和 pre-line,这在以前版本的 CSS 中是没有的。这些值的作用是允许创作人员更好地控制空白符处理。
    如果元素的 white-space 设置为 pre-wrap,那么该元素中的文本会保留空白符序列,但是文本行会正常地换行。如果设置为这个值,源文本中的行分隔符以及生成的行分隔符也会保留。pre-line 与 pre-wrap 相反,会像正常文本中一样合并空白符序列,但保留换行符。
    pre-wrap
    <style type="text/css">p {white-space: pre-wrap;}</style>
    pre-line
    <style type="text/css">p {white-space: pre-line;}</style>
    总结
    下面的表格总结了 white-space 属性的行为:
    总结:
    值  空白符  换行符  自动换行
    pre-line  合并  保留  允许
    normal  合并  忽略  允许
    nowrap  合并  忽略  不允许
    pre  保留  保留  不允许
    pre-wrap  保留  保留  允许
    8.10文本方向   direction  方向
    direction 属性有两个值:ltr 和 rtl。大多数情况下,默认值是 ltr,显示从左到右的文本。如果显示从右到左的文本,应使用值 rtl。
    例子1.文本的颜色
    <html>
    <head>
    <style type="text/css">
    body {color:red}
    h1 {color:#00ff00}
    p.ex {color:#0000ff}
    </style>
    </head>
    <body>
    <h1>这是 heading 1</h1>
    <p>这是一段普通的段落。请注意,该段落的文本是红色的。在 body 选择器中定义了本页面中的默认文本颜色。</p>
    <p class="ex">该段落定义了 class="ex"。该段落中的文本是蓝色的。</p>
    </body>
    </html>
    例2.规定字符间距
    <html>
    <head>
    <style type="text/css">
    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>
    </html>
    例3.修饰文本
    <html>
    <head>
    <style type="text/css">
    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="http://www.w3school.com.cn/index.html">这是一个链接</a></p>
    </body>
    </html>
    例4.在元素中禁止文本折行
    <html>
    <head>
    <style type="text/css">
    p
    {
    white-space: nowrap
    }
    </style>
    </head>
    <body>
    <p>
    这是一些文本。
    </p>
    </head>
    </html>
    例6.增加单词间距
    <html>
    <head>
    <style type="text/css">
    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>
    </html>
    总结: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 字体属性定义文本的字体系列、大小、加粗、风格(如斜体)和变形(如小型大写字母)。{font-family字体属性 sans-serif无衬线字体}
    body {font-family: sans-serif;}
    如果您对字体非常熟悉,也可以为给定的元素指定一系列类似的字体。要做到这一点,需要把这些字体按照优先顺序排列,然后用逗号进行连接:
    p {font-family: Times, TimesNR, 'New Century Schoolbook', Georgia, 'New York', serif;}
    1.使用引号
    您也许已经注意到了,上面的例子中使用了单引号。只有当字体名中有一个或多个空格(比如 New York),或者如果字体名包括 # 或 $ 之类的符号,才需要在 font-family 声明中加引号。
    单引号或双引号都可以接受。但是,如果把一个 font-family 属性放在 HTML 的 style 属性中,则需要使用该属性本身未使用的那种引号:
    <p style="font-family: Times, TimesNR, 'New Century Schoolbook', Georgia,'New York', serif;">...</p>
    字体的形式:正常normal;斜体italic    倾斜oblique,
    <style type="text/css">
    p.normal {font-style:normal}
    p.italic {font-style:italic}
    p.oblique {font-style:oblique}
    两者的区别在于:斜体(italic)是一种简单的字体风格,对每个字母的结构有一些小改动,来反映变化的外观。与此不同,倾斜(oblique)文本则是正常竖直文本的一个倾斜版本。
    1.2浏览器支持的文字
    font-weight 属性。
    可能的值
    normal 默认值。定义标准的字符。
    bold 定义粗体字符。
    bolder 定义更粗的字符。
    lighter 定义更细的字符
    使用 bold 关键字可以将文本设置为粗体。
    1.3字体加粗。
    关键字 100 ~ 900 为字体指定了 9 级加粗度。如果一个字体内置了这些加粗级别,那么这些数字就直接映射到预定义的级别,100 对应最细的字体变形,900 对应最粗的字体变形。数字 400 等价于 normal,而 700 等价于 bold。
    例子1.<html>
    <head>
    <style type="text/css">
    p.normal {font-weight: normal}
    p.thick {font-weight: bold}
    p.thicker {font-weight: 900}
    </style>
    </head>
    <body>
    <p class="normal">This is a paragraph</p>
    <p class="thick">This is a paragraph</p>
    <p class="thicker">This is a paragraph</p>
    </body>
    </html>
    请始终使用正确的 HTML 标题,比如使用 <h1> - <h6> 来标记标题,使用 <p> 来标记段落。
    1.4字体大小
    font-size 值可以是绝对或相对值。
    绝对值:
    将文本设置为指定的大小
    不允许用户在所有浏览器中改变文本大小(不利于可用性)
    绝对大小在确定了输出的物理尺寸时很有用
    相对大小:
    相对于周围的元素来设置大小
    允许用户在浏览器改变文本大小
    注意:如果您没有规定字体大小,普通文本(比如段落)的默认大小是 16 像素 (16px=1em)。
    使用像素来设置字体大小
    通过像素设置文本大小,可以对文本大小进行完全控制:
    例2.
    <html>
    <head>
    <style type="text/css">
    h1 {font-size:60px;}
    h2 {font-size:40px;}
    p {font-size:14px;}
    </style>
    </head>
    <body>
    <h1>This is heading 1</h1>
    <h2>This is heading 2</h2>
    <p>This is a paragraph.</p>
    <p>This is a paragraph.</p>
    <p>...</p>
    </body>
    </html>

    1.5使用 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 */
    css字体属性的总结:
    CSS 字体属性
    属性 描述
    font  简写属性。作用是把所有针对字体的属性设置在一个声明中。
    font-family   设置字体系列。
    font-size   设置字体的尺寸。
    font-size-adjust  当首选字体不可用时,对替换字体进行智能缩放(CSS2.1 已删除该属性。)
    font-stretch   对字体进行水平拉伸。(CSS2.1 已删除该属性。)
    font-style   设置字体风格。
    font-variant   以小型大写字体或者正常字体显示文本。
    font-weight   设置字体的粗细。
    2.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 之后
    2.1常见的链接样式
    在上面的例子中,链接根据其状态改变颜色。
    让我们看看其他几种常见的设置链接样式的方法:
    文本修饰
    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;}
    例子。高级 - 创建链接框
    <!DOCTYPE html>
    <html>
    <head>
    <style>
    a:link,a:visited
    {
    display:block;
    font-weight:bold;
    font-size:14px;
    font-family:Verdana, Arial, Helvetica, sans-serif;
    color:#FFFFFF;
    background-color:#98bf21;
    120px;
    text-align:center;
    padding:4px;
    text-decoration:none;
    }

    a:hover,a:active
    {
    background-color:#7A991A;
    }
    </style>
    </head>

    <body>
    <a href="/index.html" target="_blank">W3School</a>
    </body>
    </html>

    1.css列表类型
    要修改用于列表项的标志类型,可以使用属性 list-style-type:
    ul {list-style-type : square}
    1.1列表项图像
    有时,常规的标志是不够的。你可能想对各标志使用一个图像
    ul li {list-style-image : url(xxx.gif)}
    实例1.square方形 inside里面
    <html>
    <head>
    <style type="text/css">
    ul
    {
    list-style: square inside url('/i/eg_arrow.gif')
    }
    </style>
    </head>
    <body>
    <ul>
    <li>咖啡</li>
    <li>茶</li>
    <li>可口可乐</li>
    </ul>
    </body>
    </html>

    所有浏览器都支持 list-style-position 属性。
    可能的值
    值  描述
    inside  列表项目标记放置在文本以内,且环绕文本根据标记对齐。
    outside  默认值。保持标记位于文本的左侧。列表项目标记放置在文本以外,且环绕文本不根据标记对齐。
    inherit  规定应该从父元素继承 list-style-position 属性的值。
    实例2.
    <html>
    <head>
    <style type="text/css">
    ul.inside
    {
    list-style-position: inside
    }

    ul.outside
    {
    list-style-position: outside
    }
    </style>
    </head>
    <body>
    <p>该列表的 list-style-position 的值是 "inside":</p>
    <ul class="inside">
    <li>Earl Grey Tea - 一种黑颜色的茶</li>
    <li>Jasmine Tea - 一种神奇的“全功能”茶</li>
    <li>Honeybush Tea - 一种令人愉快的果味茶</li>
    </ul>
    <p>该列表的 list-style-position 的值是 "outside":</p>
    <ul class="outside">
    <li>Earl Grey Tea - 一种黑颜色的茶</li>
    <li>Jasmine Tea - 一种神奇的“全功能”茶</li>
    css列表实例
    1.在有序列表中不同类型的列表项标记,decimal 小数 upper(lower)-alpha大(小)写字母排序  lower(upper)-roman 小(大)写罗马数字
    <html>
    <head>
    <style type="text/css">
    ol.decimal {list-style-type: decimal}
    ol.lroman {list-style-type: lower-roman}
    ol.uroman {list-style-type: upper-roman}
    ol.lalpha {list-style-type: lower-alpha}
    ol.ualpha {list-style-type: upper-alpha}
    </style>
    </head>
    <body>
    <ol class="decimal">
    <li>咖啡</li>
    <li>茶</li>
    <li>可口可乐</li>
    </ol>

    <ol class="lroman">
    <li>咖啡</li>
    <li>茶</li>
    <li>可口可乐</li>
    </ol>
    总结:
    CSS 列表属性(list)
    属性 描述
    list-style 简写属性。用于把所有用于列表的属性设置于一个声明中。
    list-style-image 将图象设置为列表项标志。
    list-style-position 设置列表中列表项标志的位置。
    list-style-type  设置列表项标志的类型。
    <li>Honeybush Tea - 一种令人愉快的果味茶</li>
    </ul>
    </body>
    </html>
    2.css表格
    2.1折叠边框
    border-collapse 属性设置是否将表格边框折叠为单一边框:
    table
      {
      border-collapse:collapse;
      }

    table,th, td
      {
      border: 1px solid black;
      }
    2.2表格颜色
    下面的例子设置边框的颜色,以及 th 元素的文本和背景颜色:
    table, td, th
      {
      border:1px solid green;
      }

    th
      {
      background-color:green;
      color:white;
      }
    2.3表格内边距
    如需控制表格中内容与边框的距离,请为 td 和 th 元素设置 padding 属性:
    td
      {
      padding:15px;
      }
    2.4表格宽度和高度
    通过 width 和 height 属性定义表格的宽度和高度。
    下面的例子将表格宽度设置为 100%,同时将 th 元素的高度设置为 50px:
    table
      {
      100%;
      }

    th
      {
      height:50px;
      }
    表格的做法:
    <html>
    <head>
    <style type="text/css">
    #customers
      {
      font-family:"Trebuchet MS", Arial, Helvetica, sans-serif;
      100%;
      border-collapse:collapse;
      }
    #customers td, #customers th
      {
      font-size:1em;
      border:1px solid #98bf21;
      padding:3px 7px 2px 7px;
      }
    #customers th
      {
      font-size:1.1em;
      text-align:left;
      padding-top:5px;
      padding-bottom:4px;
      background-color:#A7C942;
      color:#ffffff;
      }
    #customers tr.alt td
      {
      color:#000000;
      background-color:#EAF2D3;
      }
    </style>
    </head>
    <body>
    <table id="customers">
    <tr>
    <th>Company</th>
    <th>Contact</th>
    <th>Country</th>
    </tr>
    <tr>
    <td>Apple</td>
    <td>Steven Jobs</td>
    <td>USA</td>
    </tr>
    <tr class="alt">
    <td>Baidu</td>
    <td>Li YanHong</td>
    <td>China</td>
    </tr>
    <tr>
    <td>Google</td>
    <td>Larry Page</td>
    <td>USA</td>
    </tr>
    <tr class="alt">
    <td>Lenovo</td>
    <td>Liu Chuanzhi</td>
    <td>China</td>
    </tr>
    <tr>
    <td>Microsoft</td>
    <td>Bill Gates</td>
    <td>USA</td>
    </tr>
    <tr class="alt">
    <td>Nokia</td>
    <td>Stephen Elop</td>
    <td>Finland</td>
    </tr>
    </table>
    </body>
    </html>
    3.css轮廓
    轮廓(outline)是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的作用。
    CSS outline 属性规定元素轮廓的样式、颜色和宽度
    例1.在元素周围画线 //dotted点线式边框 thick厚的
    <html>
    <head>
    <style type="text/css">
    p
    {
    border:red solid thin;
    outline:#00ff00 dotted thick;
    }
    </style>
    </head>
    <body>
    <p><b>注释:</b>只有在规定了 !DOCTYPE 时,Internet Explorer 8 (以及更高版本) 才支持 outline 属性。</p>
    </body>
    </html>
    例2.设置轮廓的颜色
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html>
    <head>
    <style type="text/css">
    p
    {
    border:red solid thin;
    outline-style:dotted;
    outline-color:#00ff00;
    }
    </style>
    </head>
    <body>
    <p><b>注释:</b>只有在规定了 !DOCTYPE 时,Internet Explorer 8 (以及更高版本) 才支持 outline-color 属性。</p>
    </body>
    </html>

    例3.设置轮廓的样式
    <html>
    <head>
    <style type="text/css">
    p
    {
    border: red solid thin;
    }
    p.dotted {outline-style: dotted}
    p.dashed {outline-style: dashed}
    p.solid {outline-style: solid}
    p.double {outline-style: double}
    p.groove {outline-style: groove}
    p.ridge {outline-style: ridge}
    p.inset {outline-style: inset}
    p.outset {outline-style: outset}
    </style>
    </head>
    <body>
    例4.设置轮廓的宽度
    <html>
    <head>
    <style type="text/css">
    p.one
    {
    border:red solid thin;
    outline-style:solid;
    outline-thin;
    }
    p.two
    {
    border:red solid thin;
    outline-style:dotted;
    outline-3px;
    }
    </style>
    </head>
    <body>
    <p class="one">This is some text in a paragraph.</p>
    <p class="two">This is some text in a paragraph.</p>
    <p><b>注释:</b>只有在规定了 !DOCTYPE 时,Internet Explorer 8 (以及更高版本) 才支持 outline-width 属性。</p>
    </body>
    </html>
    总结:CSS 边框属性
    "CSS" 列中的数字指示哪个 CSS 版本定义了该属性。
    属性  描述  CSS
    outline  在一个声明中设置所有的轮廓属性。 2
    outline-color 设置轮廓的颜色。 2
    outline-style 设置轮廓的样式。 2
    outline-width 设置轮廓的宽度。 2
     三。CSS 框模型
    3.1内边距
    元素的内边距在边框和内容区之间。控制该区域最简单的属性是 padding 属性。
    CSS padding 属性定义元素边框与元素内容之间的空白区域。

    CSS padding 属性
    CSS padding 属性定义元素的内边距。padding 属性接受长度值或百分比值,但不允许使用负值。
    例如,如果您希望所有 h1 元素的各边都有 10 像素的内边距,只需要这样:
    h1 {padding: 10px;}
    您还可以按照上、右、下、左的顺序分别设置各边的内边距,各边均可以使用不同的单位或百分比值:
    h1 {padding: 10px 0.25em 2ex 20%;}
    3.2单边内边距属性
    也通过使用下面四个单独的属性,分别设置上、右、下、左内边距:
    padding-top
    padding-right
    padding-bottom
    padding-left
    您也许已经想到了,下面的规则实现的效果与上面的简写规则是完全相同的:
    h1 {
      padding-top: 10px;
      padding-right: 0.25em;
      padding-bottom: 2ex;
      padding-left: 20%;
      }
    3.3内边距的百分比数值
    前面提到过,可以为元素的内边距设置百分数值。百分数值是相对于其父元素的 width 计算的,这一点与外边距一样。所以,如果父元素的 width 改变,它们也会改变。
    下面这条规则把段落的内边距设置为父元素 width 的 10%:
    p {padding: 10%;}
    例如:如果一个段落的父元素是 div 元素,那么它的内边距要根据 div 的 width 计算。
    <div style=" 200px;">
    <p>This paragragh is contained within a DIV that has a width of 200 pixels.</p>
    </div>
    注意:上下内边距与左右内边距一致;即上下内边距的百分数会相对于父元素宽度设置,而不是相对于高度。
    4.css 边框
    CSS border 属性允许你规定元素边框的样式、宽度和颜色。
    CSS 边框
    在 HTML 中,我们使用表格来创建文本周围的边框,但是通过使用 CSS 边框属性,我们可以创建出效果出色的边框,并且可以应用于任何元素。
    元素外边距内就是元素的的边框 (border)。元素的边框就是围绕元素内容和内边据的一条或多条线。
    每个边框有 3 个方面:宽度、样式,以及颜色。在下面的篇幅,我们会为您详细讲解这三个方面。
    4.2定义多种样式
    您可以为一个边框定义多个样式,例如:
    p.aside {border-style: solid dotted dashed double;}
    上面这条规则为类名为 aside 的段落定义了四种边框样式:实线上边框、点线右边框、虚线下边框和一个双线左边框。
    4.3边框的宽度 ---border-width
    为边框指定宽度有两种方法:可以指定长度值,比如 2px 或 0.1em;或者使用 3 个关键字之一,它们分别是 thin 、medium(默认值) 和 thick。
    注释:CSS 没有定义 3 个关键字的具体宽度,所以一个用户代理可能把 thin 、medium 和 thick 分别设置为等于 5px、3px 和 2px,而另一个用户代理则分别设置为 3px、2px 和 1px。
    所以,我们可以这样设置边框的宽度:
    p {border-style: solid; border- 5px;}
    或者:
    p {border-style: solid; border- thick;}
    4.4定义单边宽度
    您可以按照 top-right-bottom-left 的顺序设置元素的各边边框:
    p {border-style: solid; border- 15px 5px 15px 5px;}
    上面的例子也可以简写为(这样写法称为值复制):
    p {border-style: solid; border- 15px 5px;}
    》》》》》》》》》》》》》》》》》》》》》》》
    CSS 边框属性
    属性 描述
    border 简写属性,用于把针对四个边的属性设置在一个声明。
    border-style 用于设置元素所有边框的样式,或者单独地为各边设置边框样式。
    border-width 简写属性,用于为元素的所有边框设置宽度,或者单独地为各边边框设置宽度。
    border-color 简写属性,设置元素的所有边框中可见部分的颜色,或为 4 个边分别设置颜色。
    border-bottom 简写属性,用于把下边框的所有属性设置到一个声明中。
    border-bottom-color 设置元素的下边框的颜色。
    border-bottom-style 设置元素的下边框的样式。
    border-bottom-width 设置元素的下边框的宽度。
    border-left 简写属性,用于把左边框的所有属性设置到一个声明中。
    border-left-color 设置元素的左边框的颜色。
    border-left-style 设置元素的左边框的样式。
    border-left-width 设置元素的左边框的宽度。
    border-right 简写属性,用于把右边框的所有属性设置到一个声明中。
    border-right-color 设置元素的右边框的颜色。
    border-right-style 设置元素的右边框的样式。
    border-right-width 设置元素的右边框的宽度。
    border-top 简写属性,用于把上边框的所有属性设置到一个声明中。
    border-top-color 设置元素的上边框的颜色。
    border-top-style 设置元素的上边框的样式。
    border-top-width 设置元素的上边框的宽度。

    链接定义了如下样式:
    <html>
    <head>
    <style type="text/css"<html>
    <head>
    <style type="text/css">
    a:link, a:visited {
      border-style: solid;
      border- 5px;
      border-color: transparent;
      }
    a:hover {border-color: gray;}
    </style>
    </head>
    <body>
    <a href="#">aaa</a>
    <a href="#">BBB</a>
    <a href="#">CCC</a>
    </body>
    </html> 
    如果颜色值小于 4 个,值复制就会起作用。例如下面的规则声明了段落的上下边框是蓝色,左右边框是红色:
    p {
      border-style: solid;
      border-color: blue red;
      }
    注释:默认的边框颜色是元素本身的前景色。如果没有为边框声明颜色,它将与元素的文本颜色相同。另一方面,如果元素没有任何文本,假设它是一个表格,其中只包含图像,那么该表的边框颜色就是其父元素的文本颜色(因为 color 可以继承)。这个父元素很可能是 body、div 或另一个 table。      

    CSS 外边距属性
    属性 描述
    margin 简写属性。在一个声明中设置所有外边距属性。
    margin-bottom 设置元素的下外边距。
    margin-left 设置元素的左外边距。
    margin-right 设置元素的右外边距。
    margin-top 设置元素的上外边距。

  • 相关阅读:
    leetcode:655. 输出二叉树
    leetcode:763. 划分字母区间
    leetcode:3. 无重复字符的最长子串
    leetcode:2. 两数相加
    leetcode每日一题:409. 最长回文串
    leetcode:1381. 设计一个支持增量操作的栈
    leetcode:1380. 矩阵中的幸运数
    [数据结构] 迷宫问题(栈和队列,深搜和广搜)
    [数据结构] N皇后问题
    [2011山东ACM省赛] Sequence (动态规划)
  • 原文地址:https://www.cnblogs.com/wangyao3568/p/css_name.html
Copyright © 2020-2023  润新知