【Vue3】scoped 和样式穿透

我们使用很多 vue 的组件库(element-plus、vant),在修改样式的时候需要进行其他操作才能成功更改样式,此时就用到了样式穿透。

而不能正常更改样式的原因就是 scoped 标记。

scoped 的渲染规则:

js 复制代码
<template>
  <main>
    <el-input
      placeholder="请输入"
      class="ipt"
    ></el-input>
  </main>
</template>

<script setup lang="ts">

</script>

<style scoped lang="less">
.ipt {
  width: 300px;
  margin: 100px 400px;
}

</style>
  1. 给 HTML 的 DOM 节点增加一个不重复的 data 属性,表示它的唯一值。

  2. 编译后的生成的 css 语句,在每句 css 选择器的末尾加一个当前组件的 data 属性选择器来私有化样式。

  3. 如果组件内部包含有其他组件,只会给其他组件的最外层标签加上当前组件的 data 属性。

    此时 App 组件里面包含了 el-input 组件。

这时我们给 input 框加一个背景样式:

css 复制代码
.ipt {
  width: 300px;
  margin: 100px 400px;
  .el-input__inner {
   background: tomato; 
  }
}

此时 scoped 的第二条和第三条之间的矛盾就出现了。

.el-input__inner 里面并没有 data-v-7a7a37b1 属性,导致背景样式失效。

样式穿透解决这个问题:

  1. 如果是 Vue2:

    css 复制代码
    .ipt {
      width: 300px;
      margin: 100px 400px;
      /deep/ .el-input__inner {
       background: tomato; 
      }
    }
  2. 如果是 Vue3:

    css 复制代码
    .ipt {
      width: 300px;
      margin: 100px 400px;
      :deep(.el-input__inner) {
        background: tomato;
      }
    }

问题解决!

相关推荐
moyu843 分钟前
跨域问题解析(上):JSONP、CORS与Node代理解决方案
前端
moyu847 分钟前
深入理解TCP的三次握手与四次挥手
前端
不一样的少年_23 分钟前
头像组件崩溃、乱序、加载失败?一套队列机制+多级兜底全搞定
前端·vue.js
Code_XYZ31 分钟前
uni-app x开发跨端应用,与web-view的双向通信解决方案
前端
wordbaby32 分钟前
构建时规划,运行时执行:解构 React Router 的 prerender 与 loader
前端·react.js
用户58061393930033 分钟前
【前端工程化】Eslint+Prettier vue项目实现文件保存时自动代码格式化
前端
麦当_33 分钟前
基于 Shadcn 的可配置表单解决方案
前端·javascript·面试
MrSkye41 分钟前
从零到一:我用AI对话写出了人生第一个弹幕游戏 | Prompt编程实战心得
前端·ai编程·trae
Cutey9161 小时前
使用Canvas实现实时视频处理:从黑白滤镜到高级特效
前端·javascript
前端大卫1 小时前
前端调试太痛苦?这 6 个技巧直接解决 90% 问题!
前端·javascript