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

相关推荐
招来红月34 分钟前
记录JS 实用API
javascript
别叫我->学废了->lol在线等36 分钟前
演示 hasattr 和 ** 解包操作符
开发语言·前端·python
霍夫曼43 分钟前
UTC时间与本地时间转换问题
java·linux·服务器·前端·javascript
DARLING Zero two♡1 小时前
浏览器里跑 AI 语音转写?Whisper Web + cpolar让本地服务跑遍全网
前端·人工智能·whisper
꒰ঌ小武໒꒱1 小时前
文件上传全维度知识体系:从基础原理到高级优化
javascript·node.js
Lovely Ruby1 小时前
前端er Go-Frame 的学习笔记:实现 to-do 功能(三),用 docker 封装成镜像,并且同时启动前后端数据库服务
前端·学习·golang
深红1 小时前
玩转小程序AR-实战篇
前端·微信小程序·webvr
银空飞羽1 小时前
让Trae SOLO全自主学习开发近期爆出的React RCE漏洞靶场并自主利用验证(CVE-2025-55182)
前端·人工智能·安全
钮钴禄·爱因斯晨2 小时前
DevUI 组件生态与 MateChat 智能应用:企业级前端智能化实战
前端
不会写DN2 小时前
存储管理在开发中有哪些应用?
前端·后端