css选择器总结---总结复习,不看你就吃亏了

10 篇文章 0 订阅

选择器的作用

CSS选择器干啥的? 选择标签用的! 就是把我们想要的标签选择出来,找到特定的HTML页面元素。

h3 { 
	color: red;
}
/*
css 就是 分两件事, 选对人,  做对事。
这段代码就是2件事, 把  h3选出来,然后 把它变成了 红色。 以后我们都这么干。
*/

选择器的分类

一 基础选择器(简单)

1 通配符选择器
  • 概念: 通配符选择器用*号表示, * 就是选择所有的标签。他是所有选择器中作用范围最广的,能匹配页面中所有的元素。

  • 其基本语法格式如下:

* { 属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }

例如下面的代码,使用通配符选择器定义CSS样式,清除所有HTML标记的默认边距。

* {
  margin: 0;                    /* 定义外边距*/
  padding: 0;                   /* 定义内边距*/
}
  • 注意: 会匹配页面所有的元素,降低页面响应速度,不建议随便使用
2 标签选择器
  • 概念: 标签选择器(元素选择器)是指用HTML标签名称作为选择器,按标签名称分类,为页面中某一类标签指定统一的CSS样式。
  • 语法:

标签名{属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }

示例:

div { 
	color: red;
}
/*将所有div的字体改为红色*/
  • 作用:
    标签选择器 可以把某一类标签全部选择出来 比如所有的div标签 和 所有的 span标签
  • 优点:
    是能快速为页面中同类型的标签统一样式
  • 缺点:
    不能设计差异化样式。
3 id选择器

id选择器使用#进行标识,后面紧跟id名

  • 其基本语法格式如下:

    • id选择器

      #id名 {属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }
      
    • 标签使用

      <p id="id名"></p>
      
  • 元素的id值是唯一的,只能对应于文档中某一个具体的元素。

  • 用法基本和类选择器相同。

4 类选择器

类选择器使用“.”(英文点号)进行标识,后面紧跟类名.

  • 语法:
  .类名  {   
      属性1:属性值1; 
      属性2:属性值2; 
      属性3:属性值3;     
  }
  • 标签
<p class='类名'></p>
  • 优点:可以为元素对象定义单独或相同的样式。 可以选择一个或者多个标签

  • 注意:

    1. 类选择器使用“.”(英文点号)进行标识,后面紧跟类名(自定义,我们自己命名的)
    2. 长名称或词组可以使用中横线来为选择器命名。
    3. 不要纯数字、中文等命名, 尽量使用英文字母来表示。
5 id选择器和类选择器的区别

W3C标准规定,在同一个页面内,不允许有相同名字的id对象出现,但是允许相同名字的class。

  • 类选择器(class) 好比人的名字, 是可以多次重复使用的, 比如张三,李四,王五
  • id选择器 好比人的身份证号码, 全中国是唯一的, 不得重复。 只能使用一次。

id选择器和类选择器最大的不同在于使用次数上。

6 基础选择器总结
选择器作用缺点使用情况用法
标签选择器可以选出所有相同的标签,比如p不能差异化选择较多p { color:red;}
类选择器可以选出1个或者多个标签可以根据需求选择非常多.nav { color: red; }
id选择器一次只能选择器1个标签只能使用一次不推荐使用#nav {color: red;}
通配符选择器选择所有的标签选择的太多,有部分不需要不推荐使用* {color: red;}

二 复合选择器(有点重要哦)

1.后代选择器
  • 概念: 后代选择器又称为包含选择器
  • 作用: 用来选择元素或元素组的子孙后代
  • 其写法就是把外层标签写在前面,内层标签写在后面,中间用空格分隔,先写长辈,在写晚辈。
  • :当标签发生嵌套时,内层标签就成为外层标签的后代。
父级 子级{属性:属性值;属性:属性值;}
div .highlight {background-color: red;}

示例

    <style>
        div {
            width: 200px;
            height: 200px;
            background-color: pink;
        }
        /* 高亮被选择的元素 */
        /*这是后代选择器*/
        div .highlight {
            background-color: red;
        }
    </style>
    <div></div>
    <div>
        <p class="highlight">我会高亮</p>
    </div>
    <p class="highlight">我不会高亮</p>
    <div>
        <span>
            <p class="highlight">我的父级标签是span,我的爷爷才是div,我会高亮嘛?</p>
        </span>
    </div>

效果图:后代选择器选的是类选择器highlight, 所以只要没有类选择器的highlight的都不会高亮,但又因它是后代选择器,所以必须是嵌套在div元素下,同时有类highlight的元素才会高亮。
:只要在div里面就行,可以是div的“儿子”,也可以是div的“孙子”,“重孙”。
在这里插入图片描述

2.子元素选择器

前言:子元素选择器类似于后代选择器,只是缩小了范围,只能是儿子(记忆时可一起记忆后代选择器和子元素选择器)!!!

  • 作用: 子元素选择器只能选择作为某元素**子元素(亲儿子)**的元素。
  • 其写法就是把父级标签写在前面,子级标签写在后面,中间跟一个 > 进行连接
  • 语法:
div .highlight {background-color: red;}

示例

    div {
            width: 200px;
            height: 200px;
            background-color: pink;
        }
        /* 高亮被选择的元素 */
        /*这是子元素选择器**/
        div>.highlight {
            background-color: red;
        }

<body>
    <div></div>
    <div>
        <p class="highlight">我会高亮</p>
    </div>
    <p class="highlight">我不会高亮</p>
    <div>
        <span>
            <p class="highlight">我的父级标签是span,我的爷爷才是div,我会高亮嘛?</p>
        </span>
    </div>

</body>

效果图:
在这里插入图片描述

3.交集选择器
  • 条件:交集选择器由两个选择器构成,找到的标签必须满足:既有选择器1,也有选择器2。
  • 语法:
   div.highlight { background-color: red;}
  • 其中第一个为标签选择器,第二个为class选择器,两个选择器之间不能有空格,如div.highlight。
    示例
       div {
            width: 200px;
            height: 200px;
            background-color: pink;
        }
        /* 高亮被选择的元素 */
        
        div.highlight {
            background-color: red;
        }
<div>我不会高亮</div>
<span class="highlight">我也不会高亮</span>
<div class="highlight">哈哈哈,只有我才会高亮</div>

效果图:
在这里插入图片描述

4.并集选择器
  • 应用:如果某些选择器定义的样式相同,就可以利用并集选择器,可以让代码更简洁。并集选择器(CSS选择器分组)是各个选择器通过,连接而成的,通常用于集体声明。
  • 语法:
        #highlight,
        .highlight,
        div {
            background-color: red;
        }
  • 任何形式的选择器(包括标签选择器、class类选择器id选择器等),都可以作为并集选择器的一部分。

  • 记忆技巧:并集选择器通常用于集体声明 ,逗号隔开的,所有选择器都会执行后面样式,逗号可以理解为 和的意思。
    示例

        #highlight,
        .highlight,
        div {
            background-color: red;
        }
    <div>我高亮了</div>
    <h3 id="highlight">我也高亮了</h3>
    <p class="highlight">哈哈哈哈,我们都高亮了</p>

效果图:
在这里插入图片描述

5.复合选择器总结
选择器作用特征使用情况隔开符号及用法
后代选择器用来选择元素后代是选择所有的子孙后代较多符号是空格 .nav a
子代选择器选择 最近一级元素只选亲儿子较少符号是**>** .nav>p
交集选择器选择两个标签交集的部分既是 又是较少没有符号 p.one
并集选择器选择某些相同样式的选择器可以用于集体声明较多符号是逗号 .nav, .header

三 有点高级的选择器(哈哈哈)

1.属性选择器
  1. 什么是 CSS3

    • CSS2 的基础上拓展、新增的样式
  2. CSS3 发展现状

    • 移动端支持优于 PC
    • CSS3 目前还草案,在不断改进中
    • CSS3 相对 H5,应用非常广泛
  3. 属性选择器列表

在这里插入图片描述示例

        /* 属性选择器使用方法 */
        /* 选择的是:既是button 又有 disabled 这个属性的元素 */
        /* 属性选择器的权重是 10 */
        /* 1.直接写属性 */
        
        button[disabled] {
            cursor: default;
        }
        
        button {
            cursor: pointer;
        }
        /* 2. 属性等于值 */
        
        input[type="search"] {
            color: pink;
        }
        /* 3. 以某个值开头的 属性值 */
        
        div[class^="icon"] {
            color: red;
        }
        /* 4. 以某个值结尾的 */
        
        div[class$="green"] {
            color: green;
        }
        /* 5. 可以在任意位置的 */
        
        div[class*="blue"] {
            color: blue;
        }
    <!-- disabled 是禁用我们的按钮 -->
    <button>按钮1</button>
    <button disabled="disabled">按钮2</button>
    <input type="text" name="" id="" value="文本框">
    <input type="search" name="" id="" value="搜索框">
    <div class="icon1">icon1</div>
    <div class="icon2">icon2</div>
    <div class="1green">1green</div>
    <div class="2green">2green</div>
    <div class="1blue">1blue</div>
    <div class="blue1">blue1</div>
    <div class="1blue1">1blue1</div>

效果图:
在这里插入图片描述

2.伪类选择器

伪类选择器和类选择器有些相似,毕竟名字都这么像。请往下看呢。为了和我们刚才学的类选择器相区别,类选择器是一个点 比如 .demo {}。而我们的伪类 用 2个点 就是 冒号 比如 :link{}

1)链接伪类选择器

作用:用于向某些选择器添加特殊的效果。比如给链接添加特殊效果。

  • a:link /* 未访问的链接 */
  • a:visited /* 已访问的链接 */
  • a:hover /* 鼠标移动到链接上 */
  • a:active /* 选定的链接 */

注意

  • 写的时候,他们的顺序尽量不要颠倒 按照 lvha 的顺序。否则可能引起错误。
  • 记忆法
    • love hate 爱上了讨厌
    • **lv **包包 非常 hao
  • 因为叫链接伪类,所以都是利用交集选择器(和类是不是有点点联系了呢) a:link a:hover
  • 因为a链接浏览器具有默认样式,所以我们实际工作中都需要给链接单独指定样式。
  • 实际工作开发中,我们很少写全四个状态,一般我们写法如下:
a {   /* a是标签选择器  所有的链接 */
			font-weight: 700;
			font-size: 16px;
			color: gray;
}
a:hover {   /* :hover 是链接伪类选择器 鼠标经过 */
			color: red; /*  鼠标经过的时候,由原来的 灰色 变成了红色 */
}

咳咳:我不会做动图,也不会弄视频,效果图就不上了哈哈哈哈,忘体谅,嘻嘻。

2)结构伪类选择器
  1. 属性列表
    在这里插入图片描述
  2. 代码演示

注意!!!!表格前三个都是匹配的父元素的元素!!!!!
但是不要这么理解:认为 p:first-child 之类的选择器会选择 p 元素第一个子元素。
正确理解:p:first-child之类的选择器会选择作为某个元素中的第一个元素的p元素(用白话来讲就是,改选择器选择的元素既要是某个元素的第一个元素,又要是p元素,两个条件缺一不可),因为这种选择器选择范围比较大,所以我们常常会配合后代选择器一起使用,如 ul li:first-child

        ul li:first-child {
            background-color: red;
        }
        
        ul li:last-child {
            background-color: blue;
        }
        
        ul li:nth-child(3) {
            background-color: pink;
        }
    <ul>
        <li>1</li>
        <li>2</li>
        <li>3</li>
        <li>4</li>
        <li>5</li>
    </ul>

效果图:
在这里插入图片描述

(1)nth-child 参数详解
  1. nth-child 详解

    • 注意:本质上就是选中第几个子元素

    • n 可以是数字、关键字、公式

    • n 如果是数字,就是选中第几个

    • 常见的关键字有 even 偶数、odd 奇数

    • 常见的公式如下(如果 n 是公式,则从 0 开始计算)

    • 但是第 0 个元素或者超出了元素的个数会被忽略

    在这里插入图片描述

  2. 代码演示

    <style>
      /* 偶数 */
      ul li:nth-child(even) {
        background-color: aquamarine;
      }
    
      /* 奇数 */
      ul li:nth-child(odd) {
        background-color: blueviolet;
      }
    
      /*n 是公式,从 0 开始计算 */
      ul li:nth-child(n) {
        background-color: blue;
      }
    
      /* 偶数 */
      ul li:nth-child(2n) {
        background-color: lightskyblue;
      }
    
      /* 奇数 */
      ul li:nth-child(2n + 1) {
        background-color: lightsalmon;
      }
    
      /* 选择第 0 5 10 15, 应该怎么选 */
      ul li:nth-child(5n) {
        background-color: orangered;
      }
    
      /* n + 5 就是从第5个开始往后选择 */
      ul li:nth-child(n + 5) {
        background-color: peru;
      }
    
      /* -n + 5 前五个 */
      ul li:nth-child(-n + 5) {
        background-color: tan;
      }
    </style>
    

效果图太多了:我就演示几个

<!-- html代码都是这 -->
        <li>1</li>
        <li>2</li>
        <li>3</li>
        <li>4</li>
        <li>5</li>
        <li>6</li>
        <li>7</li>
        <li>8</li>

示例一:

        ul li:nth-child(n) {
            background-color: blue;
        }

在这里插入图片描述示例二

        ul li:nth-child(2n + 1) {
            background-color: pink;
        }

在这里插入图片描述

示例三:

        ul li:nth-child(-n + 5) {
            background-color: blue;
        }

在这里插入图片描述

nth-childnt-of-type 的区别
  • 区别

    1 nth-child 选择父元素里面的第几个子元素,不管是什么类型
    2 nth-of-type 选择指定类型的元素.

3. 伪元素选择器
  1. 伪元素选择器
    在这里插入图片描述

  2. 伪元素选择器注意事项

    • beforeafter 必须有 content 属性
    • before 在内容前面,after 在内容后面
    • beforeafter 创建的是一个元素,但是属于行内元素
    • 创建出来的元素在 Dom 中查找不到,所以称为伪元素
    • 伪元素和标签选择器一样,权重为 1
  3. 代码演示

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div {
            width: 200px;
            height: 100px;
            border: 1px solid #000000;
        }
        
        div::after,
        div::before {
            width: 50px;
            height: 50px;
            text-align: center;
            display: inline-block;
        }
        
        div::after {
            content: '德';
            background-color: skyblue;
        }
        
        div::before {
            content: '道';
            background-color: pink;
        }
    </style>
</head>

<body>
    <div>你好</div>
</body>

</html>

效果图:
在这里插入图片描述

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值