Vue组件间的样式冲突污染问题详解

 更新时间:2022年11月30日 11:30:33   作者:未及545  
默认情况下,写在.vue组件中的样式会全局生效,因此很容易造成多个组件之间的样式冲突问题。导致组件之间样式冲突的根本原因,我们接下来探究一下

默认情况下,写在.vue组件中的样式会全局生效,因此很容易造成多个组件之间的样式冲突问题。

导致组件之间样式冲突的根本原因是:

  • 单页面应用程序中,所有组件的dom结构,都是基于唯一的index.html页面进行呈现的。
  • 每个组件中的样式,都会影响整个index.html页面中的dom元素。

给left.vue文件中的p标签添加一个字体样式

<template>
  <div>
    <p >left组件</p>
    <MyCount :num="4"></MyCount>
  </div>
</template>
<script>
import MyCount from "@/components/count.vue"
export default {
components:{
    MyCount
}
}
</script>
<style>
p{color:red}
</style>

此时发现页面right.vue文件也受影响变成红色了

<template>
  <div>
    <!-- 给单个页面添加固定的自定义data-v-001属性,如此就能解决冲突问题
    一个页面最好用同一个,防止混乱
    -->
    <!-- <p data-v-001>left组件</p> -->
    <p >left组件</p>
    <MyCount :num="4"></MyCount>
  </div>
</template>
<script>
import MyCount from "@/components/count.vue"
export default {
components:{
    MyCount
}
}
</script>
<!-- 只不过上面的方法一个一个添加太过麻烦
直接在style标签上添加scoped也能解决组件样式冲突,
因为他会自动帮我们生成data-v-number
-->
<style scoped>
p{color:red}
</style>

/deep/的使用

<template>
  <div>
    <p >left组件</p>
    <MyCount :num="4"></MyCount>
   
  </div>
</template>
<script>
import MyCount from "@/components/count.vue"
export default {
components:{
    MyCount
}
}
</script>
<style scoped>
p{color:red}
/* 给count组件加样式,left和right文件都加,但是发现效果是受right的样式影响
,这是因为right没有加scoped,而此时我们想要给left文件加样式呢?
标签前面加个/deep/就行了,加上deep是[data--38a98c97] h5这样显示的,不加是h5[data--38a98c97] 
这样显示的
*/
/* 在父组件中修改子组件样式,可用deep */
 /deep/ h5{
    color:orange;
}
</style>

当使用第三方组件库的时候,如果要修改第三方组件默认样式的时候,也需要用到/deep/

到此这篇关于Vue组件间的样式冲突污染问题详解的文章就介绍到这了,更多相关Vue组件样式冲突内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue3使用v-if指令进行条件渲染的实例代码

    Vue3使用v-if指令进行条件渲染的实例代码

    条件渲染是根据条件的真假来有条件地渲染元素,在Vue.js 3.x中,常见的条件渲染包括使用v-if指令和v-show指令,本文讲解使用v-if指令进行条件渲染,需要的朋友可以参考下
    2024-03-03
  • 面试题:react和vue的区别分析

    面试题:react和vue的区别分析

    这篇文章主要介绍了react和vue的区别分析,在面试中经常会遇到,小编通过实例文字相结合的形式给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-04-04
  • vue3手动删除keepAlive缓存的方法

    vue3手动删除keepAlive缓存的方法

    当我们未设置keepAlive的最大缓存数时,当缓存组件太多,会导致内存溢出,本文给大家介绍了vue3手动删除keepAlive缓存的方法,文中通过代码示例介绍的非常详细,需要的朋友可以参考下
    2024-03-03
  • Vuex中的getter和mutation的区别详解

    Vuex中的getter和mutation的区别详解

    在现代前端开发中,状态管理是一个不可忽视的话题,而Vuex作为Vue.js的官方状态管理库,在大型应用中扮演着至关重要的角色,当我们使用Vuex进行状态管理时,getter和mutation是两个重要的概念,在本文中,我们将详细探讨getter和mutation的区别,需要的朋友可以参考下
    2024-12-12
  • vue bus全局事件中心简单Demo详解

    vue bus全局事件中心简单Demo详解

    ue-bus 提供了一个全局事件中心,并将其注入每一个组件,你可以像使用内置事件流一样方便的使用全局事件。这篇文章给大家介绍了vue bus全局事件中心简单Demo,需要的朋友参考下吧
    2018-02-02
  • vue中三元表达式方法例子

    vue中三元表达式方法例子

    这篇文章主要给大家介绍了关于vue中三元表达式的相关资料,众所周知三元表达式用来根据参数的不同执行不同的代码是很方便的,需要的朋友可以参考下
    2023-09-09
  • tdesign vue初始化组件源码解析

    tdesign vue初始化组件源码解析

    这篇文章主要为大家介绍了tdesign vue初始化组件源码解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • vue中keep-alive组件实现多级嵌套路由的缓存

    vue中keep-alive组件实现多级嵌套路由的缓存

    本文主要介绍了vue中keep-alive组件实现多级嵌套路由的缓存,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • vue写一个组件

    vue写一个组件

    这篇文章主要介绍了vue组写一个组件,需要的朋友可以参考下
    2018-04-04
  • Vue2.5通过json文件读取数据的方法

    Vue2.5通过json文件读取数据的方法

    本文通过实例代码给大家详细介绍了Vue2.5通过json文件读取数据的方法,非常不错,具有参考借鉴价值,需要的朋友参考下吧
    2018-02-02

最新评论