样式不生效/被覆盖(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; }

相关推荐
NMBG222 小时前
外卖综合项目
java·前端·spring boot
Beginner x_u2 小时前
Vue 事件机制全面解析:原生事件、自定义事件与 DOM 冒泡完全讲透
前端·javascript·vue.js·dom
Emma_Maria2 小时前
关于vant-ui-vue 的datepicker 时间选择错乱问题的处理
前端·vue.js·ui
Dabei2 小时前
Android 语音助手简单实现与语音助手“执行任务”交流
android·前端
dongczlu2 小时前
iOS 循环引用篇 菜鸟都能看懂
前端
Alsn862 小时前
26.IDEA 专业版中创建简单的 Web 项目并打包部署到本地Tomcat 9
前端·tomcat·intellij-idea
霍理迪2 小时前
HTML行内块标签——img、表单、音视频标签
前端·html
小小前端_我自坚强2 小时前
边缘函数 (Edge Functions)详解
前端
幼儿园技术家2 小时前
Hydration Mismatch 原理详解:SSR 项目中最容易踩的坑
前端