zoukankan      html  css  js  c++  java
  • 伪类(伪类选择器)

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

    静态伪类和动态伪类

    伪类选择器分为两种。

    (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:linka:visited一起定义时,如果整个浏览器的访问历史中,有网址的访问记录,则会取a:visited定义的样式,否则取a:link,比如浏览器中访问过www.baidu.com(可以不在本页面中访问过),则一出来就会是a:visited的样式

    a:linka:visited样式相同时,可以只定义a元素选择器的样式

    .nav ul li a{
                display: block;
                 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;
                 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{
             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>

    效果:

     

  • 相关阅读:
    团队项目第二阶段——第一天
    团队项目第一阶段绩效评估
    铁大树洞与市面上现有APP对比
    第一阶段其他组评价汇总
    第一阶段对其他组的评价
    铁大树洞app功能演示和使用说明
    团队冲刺——第十天
    团队冲刺——第九天
    团队冲刺——第八天
    梦断代码读后感04--毁灭即拯救
  • 原文地址:https://www.cnblogs.com/cowboybusy/p/9060128.html
Copyright © 2011-2022 走看看