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() 。

相关推荐
Setsuna_F_Seiei1 小时前
前端切图仔的一次不务正业游戏开发之旅
前端·游戏·cocos creator
laimaxgg1 小时前
Qt窗口控件之颜色对话框QColorDialog
开发语言·前端·c++·qt·命令模式·qt6.3
爱编程的鱼2 小时前
Unity—从入门到精通(第一天)
前端·unity·ue5·游戏引擎
默默无闻 静静学习2 小时前
sass介绍
前端·sass
大怪v2 小时前
前端佬们,装起来!给设计模式【祛魅】
前端·javascript·设计模式
sunly_3 小时前
Flutter:页面滚动,导航栏背景颜色过渡动画
开发语言·javascript·flutter
vvilkim3 小时前
Vue.js 插槽(Slot)详解:让组件更灵活、更强大
前端·javascript·vue.js
学无止境鸭3 小时前
uniapp报错 Right-hand side of ‘instanceof‘ is not an object
前端·javascript·uni-app
豆豆(设计前端)3 小时前
一键秒连WiFi智能设备,uni-app全栈式物联开发指南。
前端
Aphasia3113 小时前
🧑🏻‍💻前端面试高频考题(万字长文📖)
前端·面试