面试踩坑:3 类 CSS 选择器 + 4 步算清优先级逆袭攻略
moboyou 2025-06-13 07:52 4 浏览
面试时,被问到 “CSS 选择器有哪些,优先级如何计算”,是不是瞬间手心冒汗?别慌!这看似基础的问题,藏着让面试官眼前一亮的关键。今天就带你吃透 CSS 选择器,下次面试直接拿捏!
被 CSS 样式 “支配” 的恐惧
刚入行时,我接到一个任务:给页面按钮换样式。满心以为改个css样式 button { color: red; } 就能搞定,结果页面毫无反应。查了半天才发现,原来被其他样式 “覆盖” 了!这就是 CSS 选择器优先级在 “捣乱”,相信不少前端小伙伴都遇到过类似情况,明明写了样式,却不生效,急得直挠头。
CSS 选择器大揭秘
CSS 选择器主要分为三大类,每类都有自己的 “性格” 和 “优先级”。
(一)基础选择器
- 标签选择器:最直白的选择器,直接用 HTML 标签名来选中元素。
/* 选中所有的p标签 */
p {
font-size: 16px;
}
- 类选择器:通过给元素添加 class 属性来选中特定元素,使用 . 开头。
/* 选中class为"highlight"的元素 */
.highlight {
background-color: yellow;
}
- ID 选择器:每个页面中,ID 是唯一的,使用 # 开头。
/* 选中id为"main-header"的元素 */
#main-header {
color: blue;
}
(二)组合选择器
- 后代选择器:选中某个元素的后代元素,用空格分隔。
/* 选中div元素下的所有li元素 */
div li {
list-style-type: none;
}
- 子选择器:选中某个元素的直接子元素,用 > 分隔。
/* 选中div元素下的直接子元素p */
div > p {
border: 1px solid gray;
}
(三)伪类与伪元素选择器
- 伪类选择器:用于选中处于特定状态的元素,比如 :hover(鼠标悬停)、:active(点击激活)等。
/* 当鼠标悬停在a标签上时,改变颜色 */
a:hover {
color: red;
}
- 伪元素选择器:用于创建一些不在文档树中的元素,比如 ::before、::after。
/* 在p元素前面添加内容 */
p::before {
content: " ";
}
三、优先级计算:四步轻松搞定
CSS 优先级计算遵循 “四步法则”,用 a-b-c-d 来表示。
- 内联样式:a 为 1,直接写在 HTML 元素 style 属性里的样式,优先级最高。
<!-- 内联样式,优先级为1-0-0-0 -->
<div style="color: green;">我是内联样式</div>
- ID 选择器:每出现一个 ID 选择器,b 加 1。
#myDiv {
/* 优先级为0-1-0-0 */
color: blue;
}
- 类选择器、属性选择器、伪类选择器:每出现一个,c 加 1。
.myClass {
/* 优先级为0-0-1-0 */
color: orange;
}
- 标签选择器、伪元素选择器:每出现一个,d 加 1。
div {
/* 优先级为0-0-0-1 */
color: black;
}
比较优先级时,从左到右依次比较 a-b-c-d 的值,值大的优先级高。如果 a 相同,就比较 b,以此类推。
四、代码示例与对比效果
我们来看一个完整示例,感受不同选择器优先级的 “较量”。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>CSS选择器优先级示例</title>
<style>
/* 标签选择器,优先级0-0-0-1 */
div {
color: gray;
}
/* 类选择器,优先级0-0-1-0 */
.myDiv {
color: orange;
}
/* ID选择器,优先级0-1-0-0 */
#mainDiv {
color: blue;
}
/* 内联样式,优先级1-0-0-0 */
</style>
</head>
<body>
<div id="mainDiv" class="myDiv">我该是什么颜色呢?</div>
</body>
</html>
在这个例子中,最终文字颜色会是蓝色,因为 ID 选择器 #mainDiv 的优先级高于类选择器 .myDiv 和标签选择器 div。
灵活运用,提升效率
除了面试,实际开发中我们也经常会遇到需要调整 CSS 优先级的情况。比如,在引入第三方样式库时,如何用最小的改动覆盖库中的样式?这时,巧用 !important(虽然不推荐滥用)和合理提高选择器优先级就很关键。另外,当项目规模变大,样式冲突问题频发,有没有更好的命名规范和管理方法来避免优先级混乱呢?
六、模拟面试回答
面试官问起这个问题,你可以这样回答:“CSS 选择器主要有基础选择器、组合选择器,还有伪类和伪元素选择器。优先级计算就像打怪升级,内联样式是大 boss,优先级最高;ID 选择器次之;然后是类选择器、属性选择器这些;标签选择器优先级最低。比较优先级时,从高到低依次对比,谁的‘等级’高,谁的样式就生效。”
那么,你在实际项目中,你是更喜欢用 !important 快速解决样式覆盖问题,还是通过调整选择器优先级来规范样式?有人觉得 !important 简单粗暴,能快速见效;也有人认为它会破坏样式的可维护性,应该尽量避免。快来评论区分享你的看法,为自己的 “阵营” 打 call 吧!
相关推荐
- Scrcpy:一款免费、功能丰富且实用的Android镜像投屏控制软件
-
随着科技的不断发展,我们的生活中出现了越来越多的智能设备。尤其是智能手机,已经成为了我们日常生活中不可或缺的一部分。然而,有时候我们需要在电脑上操作手机,例如进行应用程序的调试、游戏挂机等。这时,拥有...
- 考公网课资源百度云网盘,公务员国考省考网课视频资源链接
-
考公网课资源百度云网盘,公务员国考省考网课视频资源链接大家好,国考将近,又到一年一度的大家冲刺的时候了,大家准备考公网课资源怎么样呢?今天来聊一聊,就是我作为一个集众多公考劣势于一身的人,是如何通过自...
- 百度推送收录工具【2025最全教程】
-
目录第一步:百度推送token获取第二步:百度推送token填写第三步:导入百度推送链接第四步:开始百度批量链接推送百度推送token获取如下图登录百度站长管理平台获取百度token注:百度token...
- 2025年公务员笔试网课视频资料百度云网盘分享(...
-
2025年公务员笔试网课视频资料百度云网盘分享(国考省考通用)2025年公务员笔试网课视频资料备考,很多小伙伴都开始了准备。有同学询问如何有效进行备考计划。考虑到在职备考的同学较多,我今天给每天有三个...
- 技术控:免百度云客户端突破下载速度
-
首先要说大神们这篇文章你可以忽视了估计方法你早就知道了首先放张图看到小编在没有使用百度云会员登陆的情况下用我们这次要介绍的下载利器IDM下载文件的时候下载速度已经达到了2.1MB/...
- 2022年中级会计师考试各科目网课视频教程百度网盘下载
-
2022年中级会计师各科目精讲班视频课件资料百度云网盘下载中级会计师资料包含:基础班/精讲班/习题班/冲刺班/押题班电子版教材适合有/无基础,需系统学习的考生中级会计师备考资料下载地址:www.34l...
- Python学不会来打我(34)python函数爬取百度图片_附源码
-
随着人工智能和大数据的发展,图像数据的获取变得越来越重要。作为Python初学者,掌握如何从网页中抓取图片并保存到本地是一项非常实用的技能。本文将手把手教你使用Python函数编写一个简单的百度图片...
- 自研雪狼引擎!百度杀毒3.0正式版评测
-
2014年10月22日,百度杀毒3.0正式版终于发布了!相比旧版,百度杀毒3.0最大的两大在于百度自家研发的雪狼杀毒引擎和冰山防御体系。如果说旧版百度杀毒的主打方向是卡巴芯保安全,那么新版的百度杀毒3...
- 百度云抢票功能怎么用 12306抢火车票攻略
-
【PConline资讯】之前我们介绍了多款抢火车票的辅助软件,这一次咱就来说一说百度浏览器出品的“云抢票功能”。百度云抢票(抢票王)功能是百度浏览器针对用户需求设计的抢火车票辅助功能,它具有“网速保...
- vue.js正确使用百度地图的方案
-
方案一:1.在index.html,加入2.在vue.config.js,配置configureWebpack:config=>{config.externals={'BM...
- SEO优化之网站怎么实现百度秒收录
-
何谓“秒收录”?大家可以经常看到,在许多大网站上,发布的新文章和外链在极短的几分钟时间内被百度索引和收录,这种现象称为“秒收”。一个网站要想关键词有排名,必须先收录!同样的一篇文章,收录快的网站,排名...
- 5分钟实现一个百度网盘资源搜索引擎,不用写代码
-
作者:msay来源:https://www.cnblogs.com/mingjiatang/p/6048193.html本文主要介绍如何通过Google的API来定义自己的搜索引擎,并将Google搜...
- 软网推荐:巧用播放器为百度网盘下载提速
-
现在国内可以选择的网络硬盘越来越少,可以选择的也只有百度网盘等极少的几家。但是百度网盘的限制也越来越多,即使是在文件下载方面也做了很多的限制,这样给用户的文件下载造成了非常大的困难。今天笔者就为大家介...
- JavaScript中10个“过时”的API,你的代码里还在用吗?
-
JavaScript作为一门不断发展的语言,其API也在持续进化。新的、更安全、更高效的API不断涌现,而一些旧的API则因为各种原因(如安全问题、性能瓶颈、设计缺陷或有了更好的替代品)被标记为“废...
- HTML5入门
-
什么是HTML5官方概念:HTML5草案的前身名为WebApplications1.0,是作为下一代互联网标准,用于取代html4与xhtml1的新一代标准版本,所以叫html5。它增加了新的标...
- 一周热门
- 最近发表
- 标签列表
-
- curseforge官网网址 (16)
- 外键约束 oracle (36)
- oracle的row number (32)
- 唯一索引 oracle (34)
- oracle in 表变量 (28)
- oracle导出dmp导出 (28)
- oracle 数据导出导入 (16)
- oracle两个表 (20)
- oracle 数据库 字符集 (20)
- oracle修改端口 (15)
- 左连接 oracle (15)
- oracle 转义字符 (14)
- oracle安装补丁 (19)
- matlab归一化 (16)
- 共轭梯度法matlab (16)
- matlab化简多项式 (20)
- 多线程的创建方式 (29)
- 多线程 python (30)
- java多线程并发处理 (32)
- 宏程序代码一览表 (35)
- c++需要学多久 (25)
- c语言编程小知识大全 (17)
- css class选择器用法 (25)
- css样式引入 (30)
- html5和css3新特性 (19)