CSS的选择符有很多,大致分为八种:

      • 通配选择符
      • 元素选择符
      • 群组选择符
      • 关系选择符
      • id及class类选择符
      • 伪类选择符
      • 属性选择符
      • 伪对象选择符

  1.通配选择符:

    可以使用模糊指定的方式来对对象进行选择。  

* {
color:blue;
background-color:red;
}

  2.元素选择符:

    指以网页中已有的标签名作为名称的选择符。  

h1{
color:red;
}

  3.群组选择符:

    对一组标签进行相同的样式定义。

                h1,p{
font-size:30px;
font-family:"微软雅黑";
color:#333;
}

  4.关系选择符:

    • 包含选择符(E F)
        选择所有被E元素包含的F元素。

      .son1 a{color:blue;}
    • 子选择符(E>F)
        选择所有作为E元素的子元素F。
      .son1>a{color:red;}
    • 相邻选择符(E+F)
            选择紧贴在E元素之后的F元素。
      .son1+div{color:green;}
    • 兄弟选择符(E~F)
            选择E元素所有的兄弟元素F。
      .son1~div{color:yellow;}

      效果图:

  5.id及class类选择符:

    id选择符:

      可以为标有特定id的HTML元素指定特定的样式,以"#"来定义,每一个id名称只能使用一次,不得重复。

      

#p1{
font-size:12px;
font-weight:bold;
}

    class选择符:

      与Id选择符不同,class可以重复使用,将多个元素使用同一个样式定义。

.p1{
font-size:12px;
font-weight:bold;
}

  6.伪类选择符

    • E:link              ——设置元素E在未被访问前的样式
    • E:visited             ——设置元素E在已被访问后的样式
    • E:hover               ——设置元素E在其鼠标悬停时的样式
    • E:active              ——设置元素E在被用户激活时的样式
                  a{text-decoration: none;}
      a:link{color:red;}
      a:hover{color:green;}
      a:active{color:blue;}
      a:visited{color:purple;}

      效果是a标签在未访问前是红色,鼠标悬停时是绿色,鼠标点击时是蓝色,访问后时紫色。

    • E:focus             ——设置元素成为输入焦点时的样式
                  input:focus{background-color: blue;}

      效果是文本框在成为输入焦点时背景变为蓝色。

    • E:lang(fr)            ——匹配使用特殊语言的元素E
    • E:not(s)              ——匹配不含s选择符的元素E
    • E:root                 ——匹配元素E的在文档的根元素,常指html元素
    • E:first-child         ——匹配父元素的第一个子元素E
    • E:last-child         ——匹配父元素的最后一个子元素E
    • E:only-child         ——匹配父元素的仅有的一个子元素E
    • E:nth-child(n)      ——匹配父元素的第n个子元素E
    • E:nth-last-child(n)   ——匹配父元素的倒数第n个子元素E
                  li:only-child{color:red;}
      
                  li:first-child{color:red;}
      li:last-child{color:blue;}
      li:nth-child(2){color:yellow;}
      li:nth-last-child(2){color:yellow;}

      效果图:

    • E:first-of-type      ——匹配同类型中的第一个同级兄弟元素E
    • E:last-of-type      ——匹配同类型中的最后一个同级兄弟元素E
    • E:only-of-type      ——匹配同类型中的唯一的一个同级兄弟元素E
    • E:nth-of-type(n)   ——匹配同类型中的第n个同级兄弟元素E
    • E:nth-last-of-type(n) ——匹配同类型中的倒数第n个同级兄弟元素E
                  .ul3 li:only-of-type{color:red;}
      
                  li:first-of-type{color:red;}
      li:last-of-type{color:blue;}
      li:nth-of-type(2){color:yellow;}
      li:nth-last-of-type(2){color:yellow;}

      效果图:

    • E:empty               ——匹配没有任何子元素的元素E
      input:empty{border-color:red;}

      效果为背景变成红色,因为input元素没有子元素。

    • E:checked                ——匹配用户界面上处于选中状态的元素E
      input[name="love[]"]:checked+label{color:blue;background-color:red;}

    • E:enabled                ——匹配用户界面上处于可用的状态的元素E
      input:enabled{color:red;}

    • E:disabled                ——匹配用户界面上处于禁用的状态的元素E
      input:disabled{color:blue;}

    • E:target                   ——匹配相关URL指向的元素E

     

  属性选择符:

    • E[att]                    ——选择具有att属性的E元素。

      p[class]{color:green;}
    • E[att="val"]            ——选择具有att属性且属性值等于val的E元素
      p[class="qq"]{color:red;}     
    • E[att~="val"]          ——选择具有att属性且属性值为用空格分隔的字词列表,其中一个等于val的E元素
      p[class~="abc"]{color:blue;}
    • E[att^="val"]          ——选择具有att属性且属性值为以val开头的字符串的E元素。
      p[class^="aa"]{color:yellow;}       
    • E[att$="val"]          ——选择具有att属性且属性值为以val结尾的字符串的E元素。
      p[class$="abc"]{color:black;}
    • E[att*="val"]          ——选择具有att属性且属性值为包含val的字符串的E元素。
      p[class*="z"]{color:orange;}
    • E[att|="val"]       ——选择具有att属性且属性值为以val开头并用连接符"-"分隔的字符串的E元素。
      p[class|="y"]{color:#ccc;}

  伪对象选择符:

    • E::first-letter          ——设置对象内的第一个字符的样式。

      p::first-letter {font-size:20px;font-weight:bold;}
    • E::first-line            ——设置对象内的第一行的样式。
      p::first-line {color:blue;}/
    • E::before               ——设置在对象前发生的内容。用来和content属性一起使用
      p::before{content:'123';}
    • E::after                 ——设置在对象后发生的内容。用来和content属性一起使用
      p::after{content:'123';}
    • E::placeholder        ——设置对象文字占位符的样式。
       input::-webkit-input-placeholder {color: green;}
    • E::selection          ——设置对象被选择时的颜色
      p::-webkit-selection{ background-color: #E13300; color: white; }

         

       

    

CSS3的chapter2的更多相关文章

  1. 使用 HTML5、CSS3 和 MathML 在 EPUB 3 中制作版式丰富的出版物

    探索用于高级排版和印刷的新一代开放电子书标准 EPUB 3.0 是最新的行业标准 XML 电子书格式,它采用了 HTML5 和 CSS3,因而融入了现代 Web 技术.它重点关注 XML 驱动的工具包 ...

  2. 纯CSS3实现的一些酷炫效果

    之前在网上看到一些用纯CSS3实现的酷炫效果,以为实现起来比较困难,于是想看看具体是怎么实现的. 一.笑脸猫动画 实现效果如下: 这个实现起来确实比较麻烦,很多地方需要花时间,有耐心地调整. 1.先看 ...

  3. CSS3 border-radius边框圆角

    在CSS3中提供了对边框进行圆角设定的支持,可对边框1~4个角进行圆角样式设置. 目录 1. 介绍 2. value值的格式和类型 3. border-radius 1~4个参数说明 4. 在线示例 ...

  4. CSS3 3D立方体效果-transform也不过如此

    CSS3系列已经学习了一段时间了,第一篇文章写了一些css3的奇技淫巧,原文戳这里,还获得了较多网友的支持,在此谢过各位,你们的支持是我写文章最大的动力^_^. 那么这一篇文章呢,主要是通过一个3D立 ...

  5. 三分钟学会用 js + css3 打造酷炫3D相册

    之前发过该文,后来不知怎么回事不见了,现在重新发一下. 中秋主题的3D旋转相册 如图,这是通过Javascript和css3来实现的.整个案例只有不到80行代码,我希望通过这个案例,让正处于迷茫期的j ...

  6. 使用CSS3实现一个3D相册

    CSS3系列我已经写过两篇文章,感兴趣的同学可以先看一下CSS3初体验之奇技淫巧,CSS3 3D立方体效果-transform也不过如此 第一篇主要列出了一些常用或经典的CSS3技巧和方法:第二篇是一 ...

  7. Web大前端时代之:HTML5+CSS3入门系列

    准备来一波新技术,待续.... Old: 联系源码:https://github.com/dunitian/LoTHTML5 文档下载:https://github.com/dunitian/LoTD ...

  8. 07. Web大前端时代之:HTML5+CSS3入门系列~H5 地理位置

    Web大前端时代之:HTML5+CSS3入门系列:http://www.cnblogs.com/dunitian/p/5121725.html 源码:https://github.com/duniti ...

  9. 前端制作动画的几种方式(css3,js)

    制作动态的网页是是前端工程师必备的技能,很好的实现动画能够极大的提高用户体验,增强交互效果,那么动画有多少实现方式,一直对此有选择恐惧症的我就总结一下,以便在开发的时候选择最好的实现方式. 1.css ...

随机推荐

  1. BizTalk 开发系列(四十一) BizTalk 2010 BAM 安装手记

    使用64位系统可以支持更大的内存,现在服务器基本上都使用64位系统.微软从Windows Server 2008 R2开始服务器版的操作系统也只支持64位了,不过对于像BizTalk这种“繁杂的东西” ...

  2. sql 错误提示

    今天在登录SqlServer2005的MicroSoft Sql Server Managerment Studio的时候,系统提示:在建立与服务器的连接时出错.在连接到SQL Server 2005 ...

  3. matlab练习程序(SUSAN检测)

    matlab练习程序(SUSAN检测) SUSAN算子既可以检测角点也可以检测边缘,不过角点似乎比不过harris,边缘似乎比不过Canny.不过思想还是有点意思的. 主要思想就是:首先做一个和原图像 ...

  4. Android课程---Activity的创建

    一.为了创建一个新的Activity,你需要继承Activity类,定义UI,实现功能.新的Activity的最基本的框架代码如下所示: package com.paad.myapplication; ...

  5. 杭电ACM题目分类

    基础题: 1000.1001.1004.1005.1008.1012.1013.1014.1017.1019.1021.1028.1029.1032.1037.1040.1048.1056.1058. ...

  6. poj1061-青蛙的约会(扩展欧几里德算法)

    一,题意: 两个青蛙在赤道上跳跃,走环路.起始位置分别为x,y. 每次跳跃距离分别为m,n.赤道长度为L.两青蛙跳跃方向与次数相同的情况下, 问两青蛙是否有方法跳跃到同一点.输出最少跳跃次数.二,思路 ...

  7. book

    http://www.ed2000.com/ShowFile.asp?FileID=61391 e-itbook.com

  8. 关于Action快捷键和小键盘的问题

    在使用全尺寸键盘的时候 键盘右边都有一排小键盘 但是这个小键盘的数字键值和普通键盘的数字键值是不一样的 在ANSI码里 标准数字键值是$30..$39, 而小键盘的键值是$60..$69 这样问题就来 ...

  9. scala在linux以及在windows的安装,以及在IDEA中新建Scala项目

    一:linux下配资scala 1.上传 2.解压 3.配置环境 4.source一下 5.启动和简单使用 6.输出语句 二:scalac的使用 1.新建文件测试目录 2.新建程序 3.文件编译器书写 ...

  10. C 数组模拟阶乘运算

    #include <stdio.h> void rdump(int arr[],int len) { ; ;i >= ; --i) { printf("%d",a ...