1.首先要知道v-deep的使用场合。

在此之前先了解一下scoped属性,scoped 属性是一个布尔属性。如果使用该属性,则样式仅仅应用到 style 元素的父元素及其子元素。

在vue中引入了scoped这个概念,scoped的设计思想就是让当前组件的样式不会修改到其它地方的样式,使用了data-v-hash的方式来使css有了它对应模块的标识,这样写css的时候不需要加太多额外的选择器,方便很多。

也就是说当我们在style中使用scoped属性会出现下面的情况:

html部分

css部分

包含其他子组件的时候

从上面的字可以看出,添加了scoped属性的组件,为了达到组件样式模块化,做了如下处理:

  • 给HTML的DOM节点加一个不重复data属性(形如:data-v-19fca230)来表示他的唯一性

  • 在每个css选择器的末尾(编译后的生成的css语句)加一个当前组件的data属性选择器(如[data-v-2311c06a])来私有化样式

  • 如果组件内部包含有其他组件,只会给其他组件的最外层标签加上当前组件的data属性,此时,在scoped里面定义的子组件的css样式将不会生效,但是如果把scoped去掉,那么就可以生效了,但是这也会造成全局样式污染的问题。

综上:使用 scoped 后,父组件的样式将不会渗透到子组件中。

为了修改子组件的样式,同时避免样式污染的问题采用如下的方法解决:

(1)写两个style标签,其中一个去掉scoped属性,并给对应的子组件添加一个类名举例如下:

<style lang="less" scoped>    //无需覆盖的样式代码 </style> 
<style lang="less">   //你覆盖的子组件样式 </style>

这样既覆盖了样式,其他样式不会被覆盖到全局(注意两个标签的顺序)。

(2)样式穿透

我们使用了/deep/深度作用选择器,这样我们就可以把样式写在scoped里,保证避免了全局样式污染,又可以实现修改子组件默认样式的需求。

如果项目使用的是css 原生样式,那么你可以直接使用 >>> 穿透修改      例如: .a >>> .b {}

如果在项目中用到了预处理器 scss 、sass、less 。这个时候用::v-deep。 例如: v-deep .a {}

2.这就是我们常用的v-deep的由来,但是使用时需要注意:

虽然在scoped作用域下,使用v-deep修改子组件的样式不会造成全局污染,但是例如:

::v-deep .el-input {}
::v-deep .el-select {}
::v-deep .el-tree {}

等等,这样的写法会将同一个文件中所有叫这个类名的组件样式都修改,假如该文件中同样包含别的组件例如,input,select,tree组件,则会造成样式的污染。所以不要直接这样写,应该添加一个我们自己的类给它包起来,这样的感觉就是我只在你外层类的里面随意的进行样式穿透,例如:

.teslib-box {
::v-deep .el-input {
//样式
}
}

3.拓展:对于一下两种方式的v-deep哪种更好

(1)
.query-testcase {
::v-deep .el-input {
//样式
}
}
(2)
::v-deep .query-testcase {
.el-input {
//样式
}
}

假如对于一个query.vue文件

我们使用v-deep当然是想改queryTestCase组件里面的某个东西的样式,假如采用第一种,那么它只会从叫query-testcase的类里面去找,也就是比较精确的定位到我们需要的组件。

假如采用第二种,我们知道使用v-deep会进行样式的穿透,那么它会将当前的query.vue文件整体去找叫query-testcase的类,假如在QueryDirectory组件或者Toolbar组件里面也有这个类

就会被定位到,从而多修改了一下样式。

综上:使用(2)这种方式会增大v-deep的作用域,我们改css最忌讳的就是篡改了其他未知的样式,因此我们尽量缩小自己css的作用域,

因此采用(1)这个写法去使用v-deep。

 

关于v-deep有你想知道的一切的更多相关文章

  1. Vim快捷输出查找寄存器的内容(去除\<,\>和\V)

    Vim自带的*搜索会自动在单词两头加上\<和\>,使用第三方的vnoremap *,则是加上前缀\V, 当我们想要输出刚刚搜索的内容时可用<C-r>/,但是很可能会带上多余的符 ...

  2. Mybatis-Plus的Service方法使用 之 泛型方法default <V> List<V> listObjs(Function<? super Object, V> mapper)

    首先 我们先看到的这个方法入参是:Function<? super Object , V> mapper ,这是jdk1.8为了统一简化书写格式引进的函数式接口 . 简单 解释一下我对Fu ...

  3. 马里奥AI实现方式探索 ——神经网络+增强学习

    [TOC] 马里奥AI实现方式探索 --神经网络+增强学习 儿时我们都曾有过一个经典游戏的体验,就是马里奥(顶蘑菇^v^),这次里约奥运会闭幕式,日本作为2020年东京奥运会的东道主,安倍最后也已经典 ...

  4. BZOJ 3083: 遥远的国度 [树链剖分 DFS序 LCA]

    3083: 遥远的国度 Time Limit: 10 Sec  Memory Limit: 1280 MBSubmit: 3127  Solved: 795[Submit][Status][Discu ...

  5. BZOJ 4196: [Noi2015]软件包管理器 [树链剖分 DFS序]

    4196: [Noi2015]软件包管理器 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1352  Solved: 780[Submit][Stat ...

  6. BZOJ 1146: [CTSC2008]网络管理Network [树上带修改主席树]

    1146: [CTSC2008]网络管理Network Time Limit: 50 Sec  Memory Limit: 162 MBSubmit: 3522  Solved: 1041[Submi ...

  7. [POJ&HDU]杂题记录

    POJ2152 树形dp,每次先dfs一遍求出距离再枚举所有点转移即可. #include<iostream> #include<cstdio> #include<cma ...

  8. Machine Learning Algorithms Study Notes(5)—Reinforcement Learning

    Reinforcement Learning 对于控制决策问题的解决思路:设计一个回报函数(reward function),如果learning agent(如上面的四足机器人.象棋AI程序)在决定 ...

  9. NOIP2013货车运输[lca&&kruskal]

    题目描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物, 司机们想知道每辆车在不超过车辆限重的情况下,最多 ...

  10. 校际联合Contest

    每次开一个坑都像是重新被碾压的预感 最近的新闻,以前很喜欢乔任梁的<复活>...然后他就死了...感觉我再多愁善感一点的话...就要悲伤逆流成河了吧... Contest 09/24(乐滋 ...

随机推荐

  1. letcode-学习-数组去重

    数组去重 问题描述: 给你一个 升序排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度.元素的 相对顺序 应该保持 一致 . 由于在某些语言中不 ...

  2. JavaScript之数组高阶API—reduce()

    一文搞懂JavaScript数组中最难的数组API--reduce() 前面我们讲了数组的一些基本方法,今天给大家讲一下数组的reduce(),它是数组里面非常重要也是比较难的函数,那么这篇文章就好好 ...

  3. 万万没想到,除了香农计划,Python3.11竟还有这么多性能提升!

    众所周知,Python 3.11 版本带来了较大的性能提升,但是,它具体在哪些方面上得到了优化呢?除了著名的"香农计划"外,它还包含哪些与性能相关的优化呢?本文将带你一探究竟! 作 ...

  4. 嵌入式-C语言:通过结构体指针操作结构体内容

    #include<stdio.h> #include<string.h> struct Student { char name[32]; int age; int height ...

  5. ubuntu 22.04安装多个gcc

    sudo apt install gcc-9 g++-9 sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-9 90 - ...

  6. uniCloud云开发入门以及对传统开发方式的思考

    事情缘由 作为选修了移动互联网应用的一员,老师讲的什么JS基础,还有ES6和uniapp,当然是没怎么听,因为是之前大二的时候都大概看过. 但是快到期末,老师讲了云开发,并且布置了与此相关的大作业,自 ...

  7. MyEclipse 中自动安插作者、注释日期等快捷键方法

    MyEclipse 中自动插入作者.注释日期等快捷键方法 MyEclipse 中自动插入作者.注释日期等de快捷键方法依次打开然后找到 Window -->Preferences->Jav ...

  8. #define 的神奇操作

    # define 的神奇操作 一.宏定义中的 #.## 符号的神奇用法 1.1 # 的用法 1.1.1 作用 #表示字符串化操作符(stringification),其作用是将宏定义中的传入参数名转换 ...

  9. 【每日一题】【直接循环&二分查找】2022年2月10日-NC32 求平方根

    描述实现函数 int sqrt(int x).计算并返回 x 的平方根(向下取整) 方法1:直接循环 import java.util.*; public class Solution { /** * ...

  10. 【JVM调优】Day01:Garbage的概念、垃圾回收的算法(标记清除、拷贝、标记压缩)、各种垃圾回收器(Serial、Parallel、CMS并发)及存在的问题

    〇.前言 简历写上:熟悉GC常用算法,熟悉常见垃圾回收器.具有实际JVM调优实战经验 瞬间涨3k 一.什么是garbage Java中垃圾回收器自动进行垃圾回收,不用自己回收 new 对象在内存中,c ...