美文网首页
vue CSS样式穿透

vue CSS样式穿透

作者: 菲儿_cdd4 | 来源:发表于2021-06-01 18:45 被阅读0次

在开发vue项目的时候,经常会引入组件。无论是第三方组件库还是自定义组件,难免会遇到防止影响其他页面上的样式,又需要在父组件修改子组件的样式。我用vue+ant专门为本文做了一个demo,给大家演示效果
demo.vue组件代码如下

<template>
  <a-card title="面板">
    <a-select label-in-value :default-value="{ key: 'lucy' }" style="width: 120px" @change="handleChange">
      <a-select-option value="jack">
        Jack (100)
      </a-select-option>
      <a-select-option value="lucy">
        Lucy (101)
      </a-select-option>
    </a-select>
  </a-card>
</template>
<script>
export default {
  methods: {
    handleChange(value) {
      console.log(value) 
    }
  }
}
</script>
<style lang="less" scoped></style>

编译运行,我们会在浏览器上看到一个select的选择器。这个选择器的宽度是默认的, 通过Chrome的开发者工具我们发现,这个组件的div上有个类名.ant-select-selection


image.png

于是我们在style标签中定义class选择器,并设置它的宽度

<style lang="less" scoped>
.ant-select {
  .ant-select-selection {
    min-width: 300px;
  }
}
</style>

修改完之后,回到浏览器,发现宽度依旧没有变化,此时通过Chrome的开发者工具查找元素,我写的样式多了一个[data-v-329d3c09]属性

<style type="text/css">
.ant-select .ant-select-selection[data-v-329d3c09] {
  min-width: 300px;
}
</style>

在网上查了一下,原来是scoped的问题,把scoped去掉之后,样式就编译成功啦

image.png
去掉scoped我们是解决了样式不编译的问题,但从官网上了解到:当一个style标签拥有scoped属性时,它的CSS样式就只能作用于当前的组件。通过设置该属性,使得组件之间的样式不互相感染,相当于实现了样式模块化。既然scoped有这么大的作用,那我们就不能去掉scoped,于是我们引入一个新的概念深度选择器,也就是穿透。使用方法:就是在我们想穿透的选择器前面添加:>>> 或者/deep/ 或者::v-deep。官方还说>>>可能存在问题,建议使用后两者,我用的是less,所以用/deep/,修改后的代码:
<style lang="less" scoped>
.ant-select {
  /deep/ .ant-select-selection {
    min-width: 300px;
  }
}
</style>

回到浏览器看效果,大功告成O(∩_∩)O哈哈~


image.png

相关文章

  • vue CSS样式穿透

    在开发vue项目的时候,经常会引入组件。无论是第三方组件库还是自定义组件,难免会遇到防止影响其他页面上的样式,又需...

  • css样式穿透

    平常在项目中肯定遇到过像是样式无法修改的问题,通过百度查询后都会发现是scopred的原因。今天小编在项目上,想要...

  • vue 样式穿透

    外层 >>> 第三方组件 { 样式 } /deep/第三方组件 { 样式 }

  • vue 样式穿透

    在如果你希望 scoped 样式中的一个选择器能够作用得“更深”,例如影响子组件,但由于scoped属性的样式隔离...

  • vue样式穿透

    深度作用选择器 1、>>> .a >>> .b {***} 2、/deep/ 或 ::v-deep :style使...

  • vue样式穿透

    1、sass和less的样式穿透 使用/deep/ 外层 /deep/ 第三方组件 做到三点:a. 当前的vue...

  • vue:样式穿透

    一、什么叫 vue 样式穿透 在 vue 开发过程中,可能会遇到修改 iview UI 组件样式的时候,无效的问题...

  • vue样式穿透

    一、目的 本文的目的主要是为了解决在带有 .... 中,无法修改ui框架的样式问题。但如果去掉scoped话...

  • vue样式穿透

    前言 vue的style中设置scoped属性后,组件实现样式私有化。但是该组件又使用的其他组件库时(vant,e...

  • vue 样式穿透

    在如果你希望 scoped 样式中的一个选择器能够作用得“更深”,例如影响子组件,但由于scoped属性的样式隔离...

网友评论

      本文标题:vue CSS样式穿透

      本文链接:https://www.haomeiwen.com/subject/jmgjjltx.html