详解vue样式穿透的几种方式

 更新时间:2022年06月29日 10:44:04   作者:汪鸿的好朋友  
本文主要介绍了vue样式穿透的几种方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

scoped属性

我们在vue组件写样式一般是在<style>标签里面,但是我们在这里的样式默认是全局样式,如果其它组件的class名取重复了则会导致样式污染。

所以vue支持在<style>标签添加scoped属性,这样当前组件的样式只会在当前样式生效,其它组件不会影响到。

例子如下:

<div class="page">
  <span class="content">hello world</span>
</div>
<style lang="scss" scoped> .page {
  .content {
    color: aquamarine;
    font-size: 20px;
  }
} </style> 

最终在浏览器渲染出来,div和span上都带有特殊属性

image.png

然后css的样式最终也会带上这些属性,根据这些属性找到元素。

image.png

这样子避免样式全局污染。

如果你的引入了第三方库,如果你想修改第三方库的样式,直接通过dom查找,修改样式是没有效果的。

比如我在项目引入了饿了么的组件库elementUI

<el-card class="box-card">
  <span class="content">hello world</span>
</el-card> 

image.png

如果我们想把padding改小一点,下面这样写是没有效果的。

<style lang="scss" scoped> .box-card {
  .el-card__body {
    padding: 10px;
  }
} </style> 

只看到默认的padding。我们写的样式没有渲染出来。

image.png

此时需要样式穿透,需要用到深度选择器/deep/

<style lang="scss" scoped> .box-card {
  /deep/.el-card__body {
    padding: 10px;
  }
} </style> 

image.png

可以看到生效了。

样式穿透

vue都是通过深度选择器来样式穿透的。除了上面的讲/deep/,我熟知的还有::v-deep>>>

那它们有何区别?

  • 如果你使用的是css,没有使用css预处理器,则可以使用>>>/deep/::v-deep
  • 如果你使用的是less或者node-sass,那么可以使用/deep/::v-deep都可以生效。
  • 如果你使用的是dart-sass,那么就不能使用/deep/,而是使用::v-deep才会生效。

总结

总结一下:

  • css可以使用>>>/deep/::v-deep
  • lessnode-sass可以使用/deep/::v-deep
  • dart-sass可以使用::v-deep

到此这篇关于详解vue样式穿透的几种方式的文章就介绍到这了,更多相关vue样式穿透内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue如何动态设置class、动态设置style

    vue如何动态设置class、动态设置style

    这篇文章主要介绍了vue如何动态设置class、动态设置style,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • WebSocket使用以及在vue如何使用问题

    WebSocket使用以及在vue如何使用问题

    这篇文章主要介绍了WebSocket使用以及在vue如何使用问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • vue如何批量引入组件、注册和使用详解

    vue如何批量引入组件、注册和使用详解

    这篇文章主要给大家介绍了关于vue如何批量引入组件、注册和使用的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-05-05
  • Vue.js 中的 v-cloak 指令及使用详解

    Vue.js 中的 v-cloak 指令及使用详解

    这篇文章主要介绍了Vue.js 中的 v-cloak 指令及使用详解,通过案例给大家简单介绍了vue中v-cloak的使用,感兴趣的朋友跟随小编一起看看吧
    2018-11-11
  • vue实现下拉框二级联动效果的实例代码

    vue实现下拉框二级联动效果的实例代码

    这篇文章主要介绍了vue实现下拉框二级联动效果,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-11-11
  • 详解Vue中router-view组件的使用

    详解Vue中router-view组件的使用

    router-view组件作为vue最核心的路由管理组件,在项目中作为路由管理经常被使用到,所以下面小编就来和大家详细聊聊router-view组件的具体使用方法,希望对大家有所帮助
    2023-06-06
  • Vue公共loading升级版解决思路(处理并发异步差时响应)

    Vue公共loading升级版解决思路(处理并发异步差时响应)

    这篇文章主要介绍了Vue公共loading升级版(处理并发异步差时响应),解决思路是通过定义一个全局对象来存储每个接口的响应状态,直到每个请求接口都收到响应才变更状态,结束loading动画,需要的朋友可以参考下
    2023-11-11
  • 关于electron打包的坑

    关于electron打包的坑

    本文主要介绍了关于electron打包的坑,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • 在Vue组件化中利用axios处理ajax请求的使用方法

    在Vue组件化中利用axios处理ajax请求的使用方法

    这篇文章主要给大家介绍了在Vue组件化中利用axios处理ajax请求的使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面跟着小编来一起学习学习吧。
    2017-08-08
  • vue单页面如何解决多个视频同时仅能播放一个问题

    vue单页面如何解决多个视频同时仅能播放一个问题

    这篇文章主要介绍了vue单页面如何解决多个视频同时仅能播放一个问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03

最新评论