伪类(伪类选择器)
伪类:同一个标签,根据其不同的种状态,有不同的样式。这就叫做“伪类”。伪类用冒号来表示。
静态伪类和动态伪类
伪类选择器分为两种。
(1)静态伪类:只能用于超链接的样式。如下:
- :link超链接点击之前
- :visited链接被访问过之后
PS:以上两种样式,只能用于超链接。
(2)动态伪类:针对所有标签都适用的样式。如下:
- :hover“悬停”:鼠标放到标签上的时候
- :active“激活”: 鼠标点击标签,但是不松手时。
- :focus是某个标签获得焦点时的样式(比如某个输入框获得焦点)
超链接的四种状态
a标签有4种伪类(即对应四种状态),要求背诵。如下:
- :link“链接”:超链接点击之前
- :visited“访问过的”:链接被访问过之后,不一定是本页面访问过,之前访问过,留在缓存里的都认为是访问过
- :hover“悬停”:鼠标放到标签上的时候
- :active“激活”: 鼠标点击标签,但是不松手时。
对应的代码如下:(带注释)
       /*让超链接点击之前是红色*/
        a:link{
            color:red;
        }
        /*让超链接点击之后是绿色*/
        a:visited{
            color:orange;
        }
        /*鼠标悬停,放到标签上的时候*/
        a:hover{
            color:green;
        }
        /*鼠标点击链接,但是不松手的时候*/
        a:active{
            color:black;记住,在css中,这四种状态必须按照固定的顺序写:
a:link 、a:visited 、a:hover 、a:active
如果不按照顺序,那么将失效。“爱恨准则”:love hate。必须先爱,后恨。
问:既然a{}定义了超链的属性,和a:link{}定义了超链点击之前的属性,那这两个有啥区别呢?
答:
a{}和a:link{}的区别:
- a{}定义的样式针对所有的超链接(包括锚点)
- a:link{}定义的样式针对所有写了href属性的超链接(不包括锚点)
如果同时需要,我们一定要将a标签写在前面,将:link、:visited、:hover、:active这些伪类写在后面。
a:link和 a:visited一起定义时,如果整个浏览器的访问历史中,有网址的访问记录,则会取a:visited定义的样式,否则取a:link,比如浏览器中访问过www.baidu.com(可以不在本页面中访问过),则一出来就会是a:visited的样式
a:link和 a:visited样式相同时,可以只定义a元素选择器的样式
.nav ul li a{
            display: block;
            width: 120px;
            height: 50px;
            text-decoration: none;
            background-color: purple;
            color:white;
        }
        .nav ul li a:hover{
            background-color: orange;
        }和
.nav ul li a{
            display: block;
            width: 120px;
            height: 50px;
        }.nav ul li a:link , .nav ul li a:visited{
            text-decoration: none;
            background-color: purple;
            color:white;
        }
        .nav ul li a:hover{
            background-color: orange;
        }效果一样
动态伪类:
我们在第一段中描述过,下面这三种动态伪类,针对所有标签都适用。
- :hover“悬停”:鼠标放到标签上的时候
- :active“激活”: 鼠标点击标签,但是不松手时。
- :focus是某个标签获得焦点时的样式(比如某个输入框获得焦点)
我们不妨来举下例子。
举例1:
  <style type="text/css">
  /*
    伪类选择器:动态伪类
  */
   /*
    让文本框获取焦点时:
    边框:#FF6F3D这种橙色
    文字:绿色
    背景色:#6a6a6a这种灰色
   */
    input:focus{
        border:3px solid #FF6F3D;
        color:white;
        background-color:#6a6a6a;
    }
    /*
    鼠标放在标签上时显示蓝色
    */
    label:hover{
        color:blue;
    }
    /*
    点击标签鼠标没有松开时显示红色
    */
    label:active{
        color:red;
    }
  </style>效果:

利用这个hover属性,我们同样对表格做一个样式的设置:
表格举例:
<!doctype html>
<html lang="en">
 <head>
  <meta charset="UTF-8">
  <meta name="Generator" content="EditPlus®">
  <meta name="Author" content="">
  <meta name="Keywords" content="">
  <meta name="Description" content="">
  <title>Document</title>
  <style type="text/css">
    /*整个表格的样式*/
    table{
        width: 300px;
        height: 200px;
        border: 1px solid blue;
        /*border-collapse属性:对表格的线进行折叠*/
        border-collapse: collapse;
    }
    /*鼠标悬停时,让当前行显示#868686这种灰色*/
    table tr:hover{
        background: #868686;
    }
    /*每个单元格的样式*/
    table td{
        border:1px solid red;
    }
  </style>
 </head>
 <body>
  <table>
  <tr>
    <td></td>
    <td></td>
    <td></td>
    <td></td>
  </tr>
  <tr>
    <td></td>
    <td></td>
    <td></td>
    <td></td>
  </tr>
  <tr>
    <td></td>
    <td></td>
    <td></td>
    <td></td>
  </tr>
  </table>
 </body>
</html>效果:

 
                    
                     
                    
                 
                    
                 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号