伪类(伪类选择器)

伪类:同一个标签,根据其不同的种状态,有不同的样式,这就叫做“伪类”。伪类用冒号来表示。伪类分为静态伪类和动态伪类

  • 静态伪类: 只能用于超链接的样式。如下:
  1. :link 超链接点击之前
  2. :visited 链接被访问过之后
    以上两种样式,只能用于超链接。
  • 动态伪类:针对所有标签都适用的样式。如下:
  1. :hover “悬停”:鼠标放到标签上的时候
  2. :active “激活”: 鼠标点击标签,但是不松手时。
  3. :focus 是某个标签获得焦点时的样式(比如某个输入框获得焦点)

超链接的四种状态

a标签有4种伪类(即对应四种状态),要求背诵。如下:

  1. :link “链接”:超链接点击之前
  2. :visited “访问过的”:链接被访问过之后,不一定是本页面访问过,之前访问过,留在缓存里的都认为是访问过
  3. :hover “悬停”:鼠标放到标签上的时候
  4. :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:linka:visited一起定义时,如果整个浏览器的访问历史中,有网址的访问记录,则会取a:visited定义的样式,否则取a:link,比如浏览器中访问过www.baidu.com(可以不在本页面中访问过),则一出来就会是a:visited的样式

a:linka: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>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容