CSS样式穿透

当我们在vue项目中使用第三方组件时,有时候需要去修改某些元素的样式,但有时写的css样式不会覆盖组件的样式,所以要用到样式穿透。

常用的方法有这几种:(1)>>> (2)/deep/ (3)::v-deep (4):deep()

但由于不同的样式解析器识别的语法不同,有时也不一定会生效。

用vant组件库的navbar组件举个例子。

​​​​​​地址:Vant 4 - A lightweight, customizable Vue UI library for mobile web apps.

vue2

使用vant组件库的版本:

修改导航栏标题的颜色,先找到标题对应的class:

html 复制代码
<template>
    <div class="world">
        <van-nav-bar title="标题" left-text="返回" left-arrow/>
    </div>
</template>

<script>
export default {

}
</script>

<style scoped>
/*.world >>> .van-nav-bar__title {*/
/*    color: red;*/
/*}*/

/*::v-deep .van-nav-bar__title{*/
/*    color: red;*/
/*}*/

/*/deep/ .van-nav-bar__title{*/
/*    color: red;*/
/*}*/

:deep(.van-nav-bar__title){
    color: red;
}
</style>

结果:

(1)当使用 css 时,这四种方法都可以生效。

(2)当使用 less 时,>>> 失效,其余三种方法都生效。

(3)当使用 sass 时,>>> 和 /deep/ 失效,其余两种方法生效。

vue3

使用vant组件库版本:

结果:

(1)当使用 css 时,>>> 失效,其余三种方法都生效。

(2)当使用 less 时,>>> 失效,其余三种方法都生效。

(3)当使用 sass 时,>>> 和 /deep/ 失效,其余两种方法生效。

虽然有些方法可以使用,但会在终端出现警告,比方说,当在使用 vue3 并且使用 less 的情况下,用 ::v-deep 和 /deep/ 生效,出现警告让使用 :deep() 。

相关推荐
重铸码农荣光几秒前
🎯 从零搭建一个 React Todo 应用:父子通信、状态管理与本地持久化全解析!
前端·react.js·架构
用户409932250212几秒前
Vue3 v-if与v-show:销毁还是隐藏,如何抉择?
前端·vue.js·后端
Mr_chiu1 分钟前
🚀 效率暴增!Vue.js开发必知的15个神级提效工具
前端
shanLion1 分钟前
Vite项目中process报红问题的深层原因与解决方案
前端·javascript
烟袅3 分钟前
从零构建一个待办事项应用:一次关于组件化与状态管理的深度思考
前端·javascript·react.js
前端小万6 分钟前
草稿
前端
闲云一鹤8 分钟前
将地图上的 poi 点位导出为 excel,并转换为 shp 文件
前端·cesium
岁月宁静1 小时前
MasterGo AI 实战教程:10分钟生成网页设计图(附案例演示)
前端·aigc·视觉设计
狗头大军之江苏分军1 小时前
快手12·22事故原因的合理猜测
前端·后端
我命由我123451 小时前
CSS 锚点定位 - 锚点定位引入(anchor-name、position-anchor)
开发语言·前端·javascript·css·学习·html·学习方法