CSS选择器以及权重顺序

简介: CSS选择器以及权重顺序

CSS选择器以及权重的设置

一个页面的搭建离不开css样式,而想要使用css对页面元素进行控制就需要用到css选择器。

按照引入方式可以说有内部样式(样式写到标签中的style里)、外部样式(样式通过引入外部的css文件)、内联样式(样式写在html文件中的style标签里)

按照选择器分类的话,常见的选择器有id选择器、类选择器、标签选择器、通配符选择器、派生选择器

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

<head>
  <meta charset="UTF-8">
  <title>Title</title>
</head>

<body>
  <div id="content" class="container">
    content1
    <div id="content2" class="container">
      content2
    </div>

  </div>

</body>
<style>
  /* div {
    color: red;
  } */

  #content {
    color: aquamarine;
  }

  .container {
    color: blue;
  }

  /* * {
    color: yellow
  } */

  div .container {
    color: rgb(224, 34, 215)
  }

  #content2 {
    color: burlywood
  }
</style>

</html>

不同的选择器,权重是不一样我们可以看到就上面的选择器而言

id>级联>class>标签>通配符

细致一点的话,再找几个例子的话,可以发现上面的并不完全正确

尤其是涉及到id跟级联这块

 div #content2 {
  color: rgb(9, 90, 45)
 }
 #content2 {
  color: burlywood
 }

可以发现,上面这种是第一个颜色显示出来,而不是根据id显示出来。

原因css通配符选择器效率低,因为css匹配的顺序不是从左向右,而是从右向左。使用通配符选择器时,浏览器会先匹配所有的元素,再进一步匹配其他规则,这样就导致了效率变低。

css的匹配规则是从右往左,也就是说,就上面的例子而言先匹配content2的元素,再匹配属于div的content元素。这样的话,即使存在下面的样式,也会被上面的覆盖掉。

至于通配符的话,他其实存在一些效率问题。毕竟匹配所有元素不如指定元素。

此外,针对class属性中有两个选择器的情况,优先级是按照定义顺序方式确定的。

<head>
  <meta charset="UTF-8">
 <title>Title</title>
</head>

<body>
  <div id="content" class="container">
 content1
    <div id="content2" class="container container2">
   content2
  </div>
 </div>
</body>
<style>
 .container2 {
  color: aqua
 }
 .container {
color: red
 }
</style>



</html>

也就是说交换上面.container和.container2的位置,字的颜色会发生变化,但是修改class=“container container2”为class=“container2 container“并不会改变字的颜色。

此外对于! important可以提高优先级值得提一下,一般不提倡使用,毕竟正常用上面的选择器有语义化,都能看懂,突然来了个插队的,怎么玩?

示例:class比id选择器更优先,因为加了个!important

 \#content {
  color: blueviolet
 }
 .container {
  color: aqua !important
 }
相关文章
|
1月前
|
XML 前端开发 数据格式
css核心组成部分包括选择器、属性和值。
【4月更文挑战第5天】css核心组成部分包括选择器、属性和值。
18 7
|
1月前
|
前端开发 开发者
提升你的CSS技能:深入理解伪类选择器和伪元素选择器!
【4月更文挑战第2天】 提升你的CSS技能:深入理解伪类选择器和伪元素选择器!
|
6天前
|
前端开发 开发者
【专栏:CSS基础篇】CSS选择器详解:精准定位网页元素
【4月更文挑战第30天】本文介绍了CSS选择器在Web开发中的重要性,详细阐述了基础选择器(元素、类、ID、属性和伪类/伪元素)及复杂选择器(后代、子元素、相邻兄弟和一般兄弟)的用法。通过理解并巧妙运用这些选择器,开发者能更高效地控制页面样式,提高代码的可维护性。CSS预处理器如Sass、LESS进一步增强了选择器的功能,助力创建优雅且强大的样式表,实现精准的网页设计。
|
7天前
|
前端开发 容器
【Web 前端】css选择器有哪些?
【4月更文挑战第22天】【Web 前端】css选择器有哪些?
|
19天前
|
前端开发
css的选择器,优先级和示例
css的选择器,优先级和示例
9 1
|
21天前
|
移动开发 前端开发 JavaScript
CSS选择器 前端开发入门笔记(十)
CSS选择器 前端开发入门笔记(十)
21 1
|
21天前
|
前端开发 JavaScript UED
CSS3选择器详解 前端开发入门笔记(六)
CSS3选择器详解 前端开发入门笔记(六)
35 1
|
21天前
|
前端开发 UED
css选择器有哪些
【4月更文挑战第15天】css选择器有哪些
19 3
|
21天前
|
前端开发 UED
css选择器是什么
【4月更文挑战第15天】css选择器是什么
19 6
|
1月前
|
前端开发 开发者
CSS面试考点:盒模型、选择器、单位和像素概念
【4月更文挑战第2天】 CSS面试考点:盒模型、选择器、单位和像素概念