样式不生效/被覆盖(CSS优先级陷阱)

问题现象

写好的CSS样式在页面上无效果,或Elements面板中样式被划掉(表示被覆盖)。

深层原因

  1. 选择器优先级不足:被更高优先级的样式覆盖。
  2. 样式拼写/取值错误 :如color写成colourfont-size: 14pxs
  3. 样式作用域问题:如Vue的scoped样式隔离。
  4. 浏览器默认样式覆盖 :如body的默认margin。

分步解决方案

步骤1:计算CSS选择器优先级(核心)

CSS优先级权重(从高到低):

  • 内联样式(style="color: red"):1000
  • ID选择器(#app):100
  • 类选择器(.box)/伪类(:hover)/属性选择器([type="text"]):10
  • 标签选择器(div)/伪元素(::before):1
  • 通配符(*)/继承样式:0

示例

css 复制代码
/* 权重:100+10=110 */
#app .box { color: blue; }

/* 权重:10(被覆盖) */
.box { color: red; }

/* 临时解决(慎用!important) */
.box { color: red !important; }
步骤2:处理Vue的scoped样式作用域

Vue的scoped样式会给元素添加唯一属性(如data-v-xxx),仅作用于当前组件的DOM。若需修改子组件样式,需用深度选择器

vue 复制代码
<style scoped>
/* Vue3 */
:deep(.child-box) { color: red; }

/* Vue2 */
::v-deep .child-box { color: red; }
</style>
步骤3:重置浏览器默认样式

使用Normalize.css或自定义重置样式,统一浏览器表现:

css 复制代码
/* 简单重置 */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box; /* 盒模型:width包含padding和border */
}
ul { list-style: none; }
a { text-decoration: none; color: inherit; }

相关推荐
BJ-Giser26 分钟前
Cesium 基于EZ-Tree的植被效果
前端·可视化·cesium
王码码20351 小时前
Flutter for OpenHarmony:Flutter 三方库 algoliasearch 毫秒级云端搜索体验(云原生搜索引擎)
android·前端·git·flutter·搜索引擎·云原生·harmonyos
发现一只大呆瓜1 小时前
深入浅出 AST:解密 Vite、Babel编译的底层“黑盒”
前端·面试·vite
天天鸭2 小时前
前端仔写了个 AI Agent,才发现大模型只干了 10% 的活
前端·python·ai编程
发现一只大呆瓜2 小时前
前端模块化:CommonJS、AMD、ES Module三大规范全解析
前端·面试·vite
IT_陈寒2 小时前
一文搞懂JavaScript的核心概念
前端·人工智能·后端
IT_陈寒2 小时前
Java开发者必看!5个提升开发效率的隐藏技巧,你用过几个?
前端·人工智能·后端
前端Hardy2 小时前
Wails v3 正式发布:用 Go 写桌面应用,体积仅 12MB,性能飙升 40%!
前端·javascript·go
Laurence2 小时前
Qt 前后端通信(QWebChannel Js / C++ 互操作):原理、示例、步骤解说
前端·javascript·c++·后端·交互·qwebchannel·互操作
Pu_Nine_92 小时前
JavaScript 字符串与数组核心方法详解
前端·javascript·ecmascript