聊聊CSS选择器

今天和大家一起聊聊CSS选择器

CSS选择器的种类

基础选择器

  • 元素选择器
js 复制代码
div {
    color: pink; 
}
  • 类选择器
js 复制代码
.div {
    color: pink; 
}
  • ID 选择器
js 复制代码
#div {
    color: pink; 
}

选择器优先级:元素选择器 < 类选择器 < ID 选择器 < 行内样式 < !important

组合选择器

后代选择器:选择某个元素下的所有指定元素。

js 复制代码
   div p {
       margin: 10px;
   }

子选择器:选择某个元素的直接子元素。

css 复制代码
ul > li {
    list-style-type: none;
}

相邻兄弟选择器:选择紧接着某个元素的下一个兄弟元素。

css 复制代码
h1 + p {
    color: red;
}

通用兄弟选择器:选择某个元素的所有兄弟元素。

css 复制代码
h1 ~ p {
    color: green;
}

属性选择器

存在属性选择器:选择具有某个属性的元素。

css 复制代码
a[target] {
    color: orange;
}

示例:

html 复制代码
<a href="https://example.com" target="_blank">选中</a> 
<a href="https://example.com">未选中</a>
js 复制代码
a[target] {
color: pink; /* 所有具有 target 属性的链接颜色为pink*/ 
}

特定属性值选择器:选择具有特定属性值的元素。

css 复制代码
   input[type="text"] {
       border: 1px solid black;
   }

示例:

js 复制代码
<input type="text" placeholder="输入文本">
<input type="password" placeholder="输入密码">
js 复制代码
input[type="text"] {
    border: 1px solid pink; /* 所有类型为 text 的输入框边框为pink */
}

伪类选择器

链接伪类:选择链接的不同状态。

css 复制代码
a:link {
    color: blue;
}
a:visited {
    color: purple;
}

悬停伪类:选择鼠标悬停时的元素。

css 复制代码
button:hover {
    background-color: lightgray;
}

偶数和奇数伪类:选择偶数或奇数行。

css 复制代码
 tr:nth-child(even) {
     background-color: #f2f2f2;
 }

伪元素选择器

选择元素的一部分

css 复制代码
p::first-line {
    font-weight: bold;
}

选择元素的特定部分

css 复制代码
p::before {
    content: "Note: ";
    font-weight: bold;
}
相关推荐
leobertlan2 小时前
2025年终总结
前端·后端·程序员
子兮曰2 小时前
OpenClaw架构揭秘:178k stars的个人AI助手如何用Gateway模式统一控制12+通讯频道
前端·javascript·github
百锦再3 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
莲华君3 小时前
React快速上手:从零到项目实战
前端·reactjs教程
百锦再3 小时前
React编程高级主题:测试代码
android·前端·javascript·react.js·前端框架·reactjs
易安说AI3 小时前
Ralph Loop 让Claude无止尽干活的牛马...
前端·后端
失忆爆表症5 小时前
05_UI 组件库集成指南:Shadcn/ui + Tailwind CSS v4
前端·css·ui
小迷糊的学习记录5 小时前
Vuex 与 pinia
前端·javascript·vue.js
发现一只大呆瓜5 小时前
前端性能优化:图片懒加载的三种手写方案
前端·javascript·面试
不爱吃糖的程序媛5 小时前
Flutter 与 OpenHarmony 通信:Flutter Channel 使用指南
前端·javascript·flutter