还在写冗余CSS、被权重打架、媒体查询套娃折磨?
新一代CSS已经彻底进化:父选择器、零权重、容器响应、样式逻辑、原生条件全部原生支持。 今天这14个实战技巧,全是大厂真实项目在用,复制粘贴就能用,让你的样式表更短、更快、更好维护。
01 :is() —— 选择器合并神器,冗余直接砍半
把重复前缀一组合,代码瞬间清爽。
/* 旧写法 */
header p, main p, footer p { line-height:1.6; }
/* 新写法 */
:is(header, main, footer) p { line-height:1.6; }
多层嵌套也能叠:
:is(header, footer) a:is(:hover, :focus) { color:#2563eb; }
02 :where() —— 零权重福音,组件样式随便覆
功能和:is()一模一样,但特异性=0,写基础样式、组件默认样式神器。
/* 权重高,难覆盖 */
article :is(h2,h3) { color:#222; }
/* 权重0,轻松覆盖 */
article :where(h2,h3) { color:#222; }
适用场景:UI库、全局重置、基础排版。
03 :has() —— 父选择器降临,干掉80%冗余JS
终于能根据子元素/兄弟关系选父级,逻辑直接写进CSS。
/* 包含图片的卡片 */
.card:has(img) { padding-top:0; border-radius:12px 12px 0 0; }
/* 表单校验失败 */
.form-group:has(input:invalid) { border-color:#ef4444; }
/* 有下拉菜单的导航项 */
nav li:has(ul) > a::after { content:"▼"; margin-left:6px; }
真正的“CSS-if逻辑”,现代浏览器全支持。
04 容器查询 —— 组件级响应式,告别视口绑架
比媒体查询强10倍:组件看容器宽度,不是看屏幕。
/* 定义容器 */
.sidebar { container-type:inline-size; }
/* 容器够宽就变横版 */
@container (min-width:380px) {
.card { display:flex; gap:16px; }
}
一套组件,适配侧边栏、弹窗、主内容区。
05 @layer 层叠规则 —— 终结权重战争
用“层优先级”代替权重内卷,结构清晰到离谱。
@layer reset, base, components, utilities;
@layer base {
body { line-height:1.5; }
}
@layer components {
.btn { padding:8px 16px; }
}
层越靠后优先级越高,再也不用!important。
06 :not() 多条件排除 —— 精准过滤,一行顶三行
新版支持多选择器并列,不用重复写:not()+:not()。
/* 排除三类元素 */
div:not(.draft, .hidden, [data-loading="true"]) {
background:#fff;
}
07 nth-child 高级公式 —— 批量排版不用加class
不用JS、不用循环,纯CSS控制间距、高亮。
/* 第4个及以后 */
li:nth-child(n+4) { margin-top:12px; }
/* 前5个加粗 */
li:nth-child(-n+5) { font-weight:600; }
/* 奇偶行 */
tr:nth-child(even) { background:#f9fafb; }
08 属性选择器通配符 —— 自动识别链接/文件/状态
像正则一样匹配,自动给链接加图标、标状态。
/* PDF链接 */
a[href$=".pdf"]::after { content:" 📄"; }
/* 外部链接 */
a[href^="http"]:not([href*="你的域名"])::after { content:" 🔗"; }
/* 数据状态 */
.card[data-status="error"] { border-color:#ef4444; }
09 :focus-visible —— 优雅焦点,不丑且可访问
只在键盘导航时显示轮廓,鼠标点击不干扰。
button:focus-visible {
outline:2px solid #2563eb;
outline-offset:2px;
}
10 :empty —— 空元素自动隐藏,布局不崩
没有文字、没有子元素,直接隐藏,不用JS判断。
section:empty, div:empty { display:none; }
11 相邻兄弟组合 —— 自动间距、排版逻辑
不用给每个元素加class,靠关系自动排版。
/* 列表项之间自动间距 */
li + li { margin-top:8px; }
/* 标题后所有段落缩进 */
h2 ~ p { padding-left:1em; }
12 color-mix() —— 原生混色,告别SASS变量
CSS自带颜色混合,主题色、渐变、透明度一键生成。
.btn {
background:color-mix(in srgb, #2563eb 80%, white 20%);
}
13 accent-color —— 表单原生着色,一行统一风格
单选、复选、滑块一键换色,不用覆盖伪元素。
input[type="checkbox"],
input[type="radio"] {
accent-color:#2563eb;
}
14 subgrid —— 嵌套网格对齐,强迫症狂喜
子网格直接继承父网格轨道,卡片高度、标题完美对齐。
.container {
display:grid;
grid-template-columns:repeat(3,1fr);
}
.card {
display:grid;
grid-template-rows:subgrid;
grid-row:span 3;
}
2026前端必背:4组黄金组合
- 复杂选择器::is() + :where() 精简代码
- 关系判断::has() 替代大量JS逻辑
- 响应式:容器查询 + 媒体查询 双剑合璧
- 工程化:@layer 管理优先级,告别权重地狱
最后
现代CSS早已不是“写样式”,而是用声明式逻辑控制UI。 这14个技巧,能让你:
- 代码量减少60%–70%
- 维护成本直线下降
- 页面更流畅、扩展性更强
建议立刻收藏,下次写CSS直接照着抄。
你用过哪几个最香?评论区聊聊~
各位互联网搭子,要是这篇文章成功引起了你的注意,别犹豫,关注、点赞、评论、分享走一波,让我们把这份默契延续下去,一起在知识的海洋里乘风破浪!