详解CSS中的基本选择器,并聊聊选择器优先级

原创
ithorizon 6个月前 (10-19) 阅读数 50 #CSS

本篇文章带大家了解一下css的5种基本选择器:元素选择器、类选择器、id选择器、通配符选择器、属性选择器,并聊聊这基本选择器的优先级,希望对大家有所帮助!

本教程操作环境:windows7系统、CSS3&&HTML5版、Dell G3电脑。

什么是选择器

CSS选择器 的作用是按照CSS规则定位HTML页面的一个或多个元素 。浏览器在解析HTML页面时,会根据CSS规则中的选择器定位HTML页面的元素,并为对应的元素设定样式。【推荐学习:css视频教程】

立即学习“前端免费学习笔记(深入)”;

CSS选择器作为CSS中的支柱,其作用好比人类的脊柱,与THML结构、浏览器行为、用户行为都相互依存相互作用,这就导致CSS选择器是非常重要的一个部分。

这里的 “选择器 ” 指的就是平常使用的CSS声明块前面的标签、类名等。如下代码所示:

div {
  color: lightcoral;
    font-size: 24px;
}

这里的div就是一个选择器。

选择器的分类

CSS从第一版本发展到第三版本,导致CSS选择器的种类越来越复杂。目前,CSS选择器的分类具体如下:

  • 基本选择器:共有5个基本选择器,是CSS选择器的最为基本的用法。

  • 层级选择器:共有4个层级选择器,是根据HTML元素之间的关系来定位HTML元素。

  • 组合选择器:具有交集和并集两种用法,是将之前基本选择器和层级选择器进行组合。

  • 伪类选择器:允许未包含在HTML页面中的状态信息选定位HTML元素。

  • 伪元素选择器:定位所有未被包含HTML的实体。

下面先带大家了解一下基本选择器,其他选择器之后介绍。

基本选择器

选择器名称举例描述

类型选择器/元素选择器

p {color:red;}选择所有

元素。

类选择器.mystyle {color:red;}选择所有class='mystyle’的标签元素
id选择器#myid {color:red;}选择所有id="myid"的标签元素

通用选择器/通配符选择器

*myid {color:red;}选择所有元素
属性选择器[id] {color:red;}选择所有id属性元素

1、元素选择器

元素选择器 又称为 类型选择器,这种基本选择器是通过HTML页面的元素名定位具体HTML元素。如果类型选择器单独使用的话,会定位当前HTML页面中所有该元素名的元素。

语法结构如下所示:

元素名 {  
  属性 : 属性值;  
 }

值得注意是 类型选择器的元素名是不区分大小写的。

示例代码如下:

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>类型选择器</title>
    <style>
        /* 选择标签名为 h1 的元素,设置字体的颜色为红色 */
        h1 {
            color: lightcoral;
        }
    </style>
</head>

<body>
    <h1>一级标题</h1>
    <h2>二级标题</h2>
</body>

</html>

代码运行结果如下图所示:

2、类选择器

类选择器 是通过HTML元素的class属性的值定位具体HTML元素。这种基本选择器的用法是 .类名形式。

语法结构如下所示:

.类名 {
  属性 : 属性值;
}

示例代码如下:

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>类选择器</title>
    <style>
        /* 设置所有带有 title 类名的元素 */
        .title {
            color: lightsalmon;
        }
    </style>
</head>

<body>
    <!-- 为 h1 h2 h3 元素增加一个 title 的类名,可以通过类选择器统一控制 -->
    <h1>一级标题</h1>
    <h2>二级标题</h2>
    <h3>二级标题</h3>
</body>

</html>

代码运行结果如下图所示:

下图展示了类选择器的分析结构:

在HTML中可以为一个元素添加多个类名,示例代码如下:

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>类选择器</title>
    <style>
        .title {
            color: lightsalmon;
        }

        /* 任意选择一个类名设置即可 */
        .h3 {
            color: lawngreen;
        }
    </style>
</head>

<body>
    <h1>一级标题</h1>
    <h2>二级标题</h2>
    <!-- 多个类型通过空格进行分割 -->
    <h3 class="title h3">二级标题</h3>
</body>

</html>

代码运行结果如下图所示:

元素的字体与前面不一样的原因是因为相同优先级时,越靠后优先级越高。

3、ID选择器

ID选择器类选择器 类似,都是根据某个属性来匹配HTML元素的,类选择器匹配的是class选择器,而ID选择器匹配的是id属性。值得注意的是,ID属性在整个页面中是唯一不可重复的

语法结构如下:

#ID {
  属性 : 属性值;
}

用法与类选择器类似,这里不做赘述。只需要注意id属性唯一不可重复即可。

一个ID值在一个HTML文档中只能出现一次,也就是一个ID只能唯一标识一个元素(不是一类元素,而是一个元素)。

即元素的 id 在页面中是唯一的,因此 id 选择器用于选择一个唯一的元素!

示例:

#div1{
    background:rgb(200,200,0);
    color:blue;
    font-size:20px;
}

运行结果

<p>这是一个段落</p>
<p id="div1">这是一个段落</p>

注意:由于id属性的唯一性,一般使用css做样式不使用该选择器,而该选择器的主要用途是用来做js特效

4、通用选择器

通用选择器 又称为通配符选择器 ,是一个星号(*),这个选择器是一个特殊的标签选择器,它可以指代所有类型的标签元素,包括自定义元素,以及

相关标签: css html5 css css3 html class JS 选择器 伪类 伪元素 来源:csdn网 收藏 点赞 上一篇:css定位详解--相对定位、绝对定位和固定定位 下一篇:CSS布局属性控制元素的隐藏与显示 本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn 作者最新文章
  • POPO是什么? 2024-06-08 22:20:24
  • 谷歌三件套指的是哪三个软件 2024-06-08 20:01:09
  • 什么是web3?大白话解析web3形态 2024-01-18 14:52:42
  • vpc网络是什么意思 2023-10-08 17:47:13
  • gmail是什么邮箱 2023-10-08 17:42:34
  • 网络攻击的种类有哪些? 2023-10-08 17:22:59
  • 云什么意思? 2023-10-08 17:16:01
  • 支付通是什么平台 2023-09-12 14:49:39
  • HMS Core是什么软件 2023-08-17 11:25:41
  • Word文本框没有旋转按钮怎么办 2023-06-16 17:27:27
最新问题 用了gard("admin")还需要单独验证吗? 在控制器中用了gard("admin")->attempt($rules)后还需要单独写查询语句验证吗? P粉709840553来自于2024-09-24 11:07:51 0 0 446 为什么password密码在数据据值都不样 自动生成后在数据库password这个字段中为什么会出现值不一样,生成都是用的是:admin888 P粉709840553来自于2024-09-24 11:06:02 0 0 372 运行视频看不了啊 运行视频看不了啊 P粉109248948来自于2024-09-24 10:21:09 0 0 281 为啥开头不写结束符号 ?> 就写一个<?php 为啥开头不写结束符号   ?>   就写一个<?php P粉052048067来自于2024-09-11 18:01:19 0 1 700 按照老师的方法不传值给TP6后台,再接收参数。出现以下错误。怎么办 http://localhost/index.php/admin/index/userliste 的远程资源。(原因:CORS 头缺少 'Access-Control-Al... 凡人来自于2024-07-09 15:20:49 1 39 2107 请问写php项目都要用到git吗 请问写php项目都要用到git吗 IT视界用户-4202961来自于2024-06-11 14:28:59 0 57 2712 请问能提供下源码么 请问能提供下源码么?想对照着看 周珂儿来自于2024-06-06 08:56:32 0 47 2427 为什么我用的laravel10不走handle文件中的render方法,无法输出断点内容 为什么我用的laravel10不走handle文件中的render方法,无法输出断点内容 许飞来自于2024-06-02 14:41:32 0 50 1877 小鱼AI助手免费使用!http://ai.52xuejs.cn/#/chat 小鱼AI助手免费使用!http://ai.52xuejs.cn/#/chat 会飞的汤姆来自于2024-05-28 03:09:58 0 47 2473 function_exists()无法判定自定义函数 function test()    {        return true;    } ... 凡人来自于2024-04-29 11:01:01 0 64 3304 相关专题 更多>
  • html5动画制作有哪些制作方法
  • HTML与HTML5的区别
  • css
  • css居中
  • css如何插入图片
  • css超出显示...
  • css字体颜色
  • 什么是css


热门