scss下解决父组件中使用::v-deep修改样式穿透到子组件的问题

开发中经常会用到深度选择器来修改第三方组件库等子组件的样式,这时候就用到样式穿透(style Penetration)

样式穿透的方式有:>>>、 /deep/、::v-deep这三种

使用中发现了一个问题,就是当在父组件使用了v-deep修改自身组件或者第三方组件样式时,会影响到子组件中的样式,

第一种方式:

使用>>>修改无效,原因是scss等预处理器却无法解析>>>

第二种:

而使用/deep/修改时报SassError: expected selector. 原因是sass不支持这个选择器。

第三种,使用::v-deep,

使用方式:要修改的元素外层套一层box,修改样式时加在选择器前,这样就可以将要修改的的元素限制在当前文件,如下,需要修改class为v-tabs__nav的元素时:

javascript 复制代码
 .tabs-wrap ::v-deep.v-tabs__nav{
   background-color: transparent !important;
 }
相关推荐
小雨下雨的雨几秒前
蜡笔小画家鸿蒙PC用Electron框架 - 儿童学画蜡笔画技术实现详解
前端·javascript·华为·electron·前端框架·交互·鸿蒙系统
天蓝色的鱼鱼几秒前
别只拿 Playwright 写测试,这三个野路子用法才是真香
前端
SoaringHeart3 分钟前
Flutter进阶|源码修改:DecorationImage 添加网络图片占位图
前端·flutter
小新1108 分钟前
vue 实战项目 天气查询
前端·javascript·vue.js
7yue8 分钟前
用 TypScript 学习 Claude Code
前端·typescript·claude
Rain5099 分钟前
实战:搭建 AI Code Review 自动化流水线
前端·人工智能·git·ci/cd·自动化·ai编程·代码复审
Nian_Baikal10 分钟前
从零搭建离线地图服务:Nginx + Cesium/Leaflet 实战指南
前端
问心无愧051310 分钟前
ctf show web入门99
android·前端·笔记
用户6000718191012 分钟前
【翻译】CSS 与 JavaScript:动画性能该怎么选
前端