通用选择器会影响性能吗_在大页面中如何合理使用
技术百科
P粉602998670
发布时间:2026-01-28
浏览: 次 通用选择器 * 严重拖慢渲染性能,因需遍历所有 DOM 元素匹配,导致首屏延迟10–30ms;应改用精准标签重置、all: unset 或 box-sizing 优化,避免嵌套与低效组合。
通用选择器 * 确实会拖慢渲染性能
浏览器解析 CSS 时,* 会匹配页面中所有节点,强制引擎对每个 DOM 元素都做一次样式匹配计算。在 DOM 节点数超 5000 的页面里,这个过程可能让首次渲染延迟 10–30ms,尤其在低端设备或旧版 Safari 中更明显。
它还会干扰 CSS 引擎的优化机制——比如 Chrome 的“快速拒绝”策略(跳过明显不匹配的选择器)对 * 完全失效,因为「所有元素都可能匹配」。
- 避免写成
* { margin: 0; padding: 0; }这类全局重置,改用更精准的标签组合(如body, h1, p, ul, li, input, button { margin: 0; padding: 0; }) - 不要嵌套使用:
div * span比div span多出一个通配层级,匹配开销指数级上升 - 构建工具(如 PostCSS)可配置
stylelint规则selector-no-universal提前拦截
真正需要「通用重置」时,优先用 all: unset
all: unset 是现代替代方案:它把元素还原为无样式初始状态,且只作用于声明该规则的元素及其后代,不会触发全树遍历。兼容性上,Chrome 37+、Firefox 27+、Safari 9.1+ 均支持;IE 完全不支持,但 IE 场景下本就不该依赖复杂 CSS 重置。
注意它和 all: initial 的区别:unset 对继承属性表现为继承,对非继承属性表现为 initial;而 all: initial 会让所有属性(包括 display)都回退到初始值,可能导致布局崩溃。
- 安全写法:
*, *::before, *::after { box-sizing: border-box; }可保留(仅影响一个属性,且现代浏览器对此有专门优化) - 慎用
all: unset在组件根节点——某些框架(如 Vue)的v-html内容可能意外被重置 - 若需兼容 IE,仍可用
normalize.css或手写精简版标签重置,而非*
大页面中更值得警惕的是「低效组合选择器」
比 * 更常被忽略的性能陷阱,是深层嵌套 + 通用/属性选择器混用,例如:article div[role="button"] > *:nth-child(2n)。这类选择器迫使浏览器从右往左匹配时,先收集所有偶数子元素,再逐层向

- 把能确定的标签名写出来:用
article footer button替代article footer > * - 避免在高频更新区域(如列表项、弹窗内容)使用
:hover+*组合(例如.list-item:hover * { opacity: 0.8; }) - 用浏览器 DevTools 的「Rendering」面板开启「Paint flashing」,观察 hover 或滚动时是否大面积闪烁——那是样式重算/重排的信号
实际项目中,性能问题往往出在「看不见的地方」
很多人盯着关键路径的 JS 执行时间,却没检查 CSSOM 构建阶段。一个未压缩的 node_modules 样式包(比如某 UI 库的完整 CSS)可能悄悄注入几十条含 * 或 [attr] 的规则,而你在自己的代码里根本没写过它们。
建议上线前跑一次 npm run build 后的最终 CSS 文件,用正则 /\*\s*{|\*\s*\+/g 搜索残留的通配符,并结合 CSS Usage 插件确认这些规则是否真被用到。
最麻烦的不是写错,而是团队协作中没人 review CSS 性能——它不像 JS 错误会直接报红,而是在用户滑动卡顿、动画掉帧时才暴露。
# ai
# safari
# 浏览器
# css
# 工具
# js
# html
# 区别
# chrome
# node
# 继承
# firefox
# npm
# vue
# 属性选择器
# postcss
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- Win10如何设置双wan路由器 Win10双wa
- Windows10如何更改系统字体大小_Win10
- php485返回数据不完整怎么办_php485数据
- php本地部署支持nodejs吗_php与node
- Win11触摸板没反应怎么办_开启Win11笔记本
- 如何用::实现工具类方法调用_php静态工具类设计
- c++怎么实现大文件的分块读写_c++ 文件指针s
- c# Task.Yield 的作用是什么 它和Ta
- 如何在Golang中处理云原生事件_使用Event
- 怎么将XML数据可视化 D3.js加载XML
- c# 服务器GC和工作站GC的区别和设置
- win11 OneDrive怎么彻底关闭 Win1
- Python项目回滚策略_发布安全说明【指导】
- Linux如何使用Curl发送请求_Linux下A
- Windows 11无法安全删除U盘提示设备正在使
- Python与OpenAI接口集成实战_生成式AI
- Windows 10怎么隐藏特定更新补丁_Wind
- Win11笔记本怎么看电池健康度_Win11电池报
- php下载安装包太大怎么下载_分卷压缩下载方法【教
- Win11怎么设置快速访问_Windows11文件
- Win11怎么退出高对比度模式_Win11取消反色
- Win11怎么设置触控板手势_Windows11三
- Win11怎么检查TPM2.0模块_Windows
- C#如何使用Channel C#通道实现异步通信
- Win11怎么退出微软账户_切换Win11为本地账
- 如何在 Go 中正确测试带 Cookie 的 HT
- Win11怎么开启剪贴板历史记录_Windows1
- Win11怎么设置声音输出设备_Windows11
- Win11怎么更改任务栏颜色_Windows11个
- php删除数据怎么软删除_添加is_del字段标记
- Windows资源管理器总是卡顿或重启怎么办?(修
- Win10系统更新错误0x80240034怎么办
- Win11无法拖拽文件到任务栏怎么办_Win11开
- 如何在Golang中实现微服务负载均衡_Golan
- c++如何获取map中所有的键_C++遍历键值对提
- Mac如何修复应用程序权限问题_Mac磁盘工具修复
- Django 密码修改后会话失效的解决方案
- Mac如何使用听写功能_Mac语音输入打字【效率技
- Win11怎么设置默认PDF阅读器 Win11修改
- Win11怎么清理C盘系统日志_Win11清理系统
- Win11怎么设置默认输入法 Win11固定中文输
- 如何使用Golang实现微服务事件驱动_使用消息总
- Win11怎么设置多显示器任务栏 Win11扩展任
- Win11系统占用空间大怎么办 Win11深度瘦身
- Windows怎样关闭开始菜单广告_Windows
- Win11怎么关闭定位服务_保护Win11位置隐私
- 如何在Golang中写入XML文件_生成符合规范的
- c# 如何深拷贝和浅拷贝
- Win11怎么清理C盘虚拟内存_Win11清理虚拟
- Win11截图快捷键是什么_Win11自带截图工具

QQ客服