vue样式问题

全局子组件,引入到页面中,页面中关于子组件样式的重写不生效的问题,比如全局头部组件src/components/HHeader.vue,然后在登录页login.vue中引入了这个头部组件

全局css中,已经定义了头部的样式,这个样式后面大部分的页面都在公用。

css 复制代码
比如全局中css样式是:
.header .header_inner {
  display: flex;  align-items: center;
  justify-content: space-between;
  height: 0.44rem;  line-height: 0.44rem;
  border-bottom: 1px solid #e7e7e7;}

但是登录页面头部样式略微有些区别,需要重写,这个时候,如果在login.vue中写下面这段代码,会发现根本不生效

xml 复制代码
<style scoped>
.header .header_inner {  border-bottom: none !important;}</style>

究其原因,主要是因为**Vue 的 scoped 样式限制。**在 login.vue 文件中,CSS 规则被放在了

xml 复制代码
<style scoped>

标签内,这意味着这些样式只会应用到当前组件的元素上,而不会影响子组件内部的元素。

而 .header 和 .header_inner 这两个类实际上是在 HHeader 组件内部定义的,不是直接在 login.vue 的模板中定义的。当你使用 组件时,其内部的 DOM 结构对于 login.vue 的 scoped 样式来说是不可见的。

解决方案:

使用深度选择器:在 login.vue 中修改你的 CSS 规则,使用 Vue 的深度选择器来穿透 scoped 限制:

css 复制代码
/* 在 login.vue 中使用 */.header ::v-deep .header_inner {  border-bottom: none !important;}

如果你的vue版本较高,也可以使用新的语法

css 复制代码
/* 较新的 Vue 版本 */.header :deep(.header_inner) {  border-bottom: none !important;}

另外还有一种不太推荐的方式,就是去掉页面内的**scoped属性,但是这种会作用到全局,不推荐**

xml 复制代码
不推荐
<style>/* 全局样式,可以影响子组件 */.header .header_inner {  border-bottom: none !important;}</style>
相关推荐
幻影星空VR元宇宙6 小时前
飞行影院设备价格解析及性价比分析
css·百慕大冒险·幻影星空
VX:Fegn08957 小时前
计算机毕业设计|基于springboot + vue校园社团管理系统(源码+数据库+文档)
前端·数据库·vue.js·spring boot·后端·课程设计
低保和光头哪个先来10 小时前
场景6:对浏览器内核的理解
开发语言·前端·javascript·vue.js·前端框架
+VX:Fegn089510 小时前
计算机毕业设计|基于springboot + vueOA工程项目管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·课程设计
进击的野人11 小时前
Vue Router 深度解析:从基础概念到高级应用实践
前端·vue.js·前端框架
JIngJaneIL12 小时前
基于java+ vue学生成绩管理系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·后端
老华带你飞12 小时前
智能菜谱推荐|基于java + vue智能菜谱推荐系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
汐泽学园13 小时前
基于Vue的幼儿绘本阅读启蒙网站设计与实现
前端·javascript·vue.js
爱上妖精的尾巴14 小时前
7-2 WPS JS宏 Object对象属性的查、改、增、删
前端·javascript·vue.js
源码获取_wx:Fegn089514 小时前
基于springboot + vueOA工程项目管理系统
java·vue.js·spring boot·后端·spring