设为首页
收藏本站
导读
Guide
排行榜
Ranklist
打卡
游戏
有奖推广
登录
立即注册
数独
象棋
五子棋
游戏勋章
DisCoke
»
节点
›
站长圈子
›
站长茶馆
›
2026现代CSS实战:14个神级技巧,代码直接少写70% ...
返回列表
发布新帖
[分享]
2026现代CSS实战:14个神级技巧,代码直接少写70%
10
0
九三郎
Lv.9
发表于
昨天 14:26
|
查看全部
阅读模式
马上登陆,轻松畅玩DC.
您需要
登录
才可以下载或查看,没有账号?
立即注册
×
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:[color=#576b95 !important][url=]#2563eb[/url]; }
复制代码
02 :where() —— 零权重福音,组件样式随便覆
功能和:is()一模一样,但特异性=0,写基础样式、组件默认样式神器。
/* 权重高,难覆盖 */
article :is(h2,h3) { color:[color=#576b95 !important][url=]#222[/url]; }
/* 权重0,轻松覆盖 */
article :where(h2,h3) { color:[color=#576B95 !important][url=]#222[/url]; }
复制代码
适用场景: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:[color=#576B95 !important][url=]#ef4444[/url]; }
/* 有下拉菜单的导航项 */
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:[color=#576B95 !important][url=]#fff[/url];
}
复制代码
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:[color=#576B95 !important][url=]#f9fafb[/url]; }
复制代码
08 属性选择器通配符 —— 自动识别链接/文件/状态
像正则一样匹配,自动给链接加图标、标状态。
/* PDF链接 */
a[href$=".pdf"]::after { content:" 📄"; }
/* 外部链接 */
a[href^="http"]:not([href*="你的域名"])::after { content:" 🔗"; }
/* 数据状态 */
.card[data-status="error"] { border-color:[color=#576B95 !important][url=]#ef4444[/url]; }
复制代码
09 :focus-visible —— 优雅焦点,不丑且可访问
只在键盘导航时显示轮廓,鼠标点击不干扰。
button:focus-visible {
outline:2px solid [color=#576B95 !important][url=]#2563eb[/url];
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:[color=#576B95 !important][url=]#2563eb[/url];
}
复制代码
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直接照着抄。
回复
使用道具
举报
返回列表
发布新帖
回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
本版积分规则
发表回复
回帖并转播
回帖后跳转到最后一页
九三郎
Lv.9 管理员
主题
11
回帖
42
积分
148
+ 关注
发消息
图文热点
测试内容
5 人气
#DZ综合
N7模版门户首页右上DIY论坛信息
12 人气
#DZ综合
DZ新插件预告
18 人气
#DZ综合
今天最热门的几张造谣AI图,做的是一个比一
36 人气
#站长茶馆
推荐话题
1
涨姿势的小众网站,正乌泱泱的朝你走来。。。
108 阅读
梦淡如非
2
抽奖(积分奖励,兼做抽奖测试)
79 阅读
九三郎
3
月亮影响你写诗作画吗?
103 阅读
梦淡如非
4
想想都要笑了,这个周末居然有3天不用调休的小长假。
96 阅读
九三郎
5
DC论坛游戏大军新增牛马数独
98 阅读
D哥
最新发布
测试内容
2026现代CSS实战:14个神级技巧,代码直接
N7模版门户首页右上DIY论坛信息
DZ新插件预告
测试类别
今天最热门的几张造谣AI图,做的是一个比一
500 万是多少钱?
中国 AI 教育现状,已经完成闭环了
浏览过的版块
遇见AI
DZ综合
关灯
在本版发帖
扫一扫添加微信客服
返回顶部
快速回复
返回顶部
返回列表