vue3样式穿透用法

在Vue3中,样式穿透可通过以下方式实现:

1. 基础用法

使用::v-deep伪类实现样式穿透(兼容Vue2语法):

css 复制代码
.parent ::v-deep .child-component {
  color: red;
}

2. 推荐方式

使用:deep()伪函数(Vue3推荐写法):

css 复制代码
.parent :deep(.child-component-inner) {
  padding: 10px;
}

3. 插槽内容样式

使用:slotted()处理插槽内容:

css 复制代码
:slotted(.slot-content) {
  background: #f0f0f0;
}

4. 全局样式

在scoped样式中定义全局规则:

css 复制代码
:global(.global-class) {
  font-size: 16px;
}

5. 动态选择器

结合属性选择器使用:

css 复制代码
:deep([data-test="item"]) {
  border: 1px solid blue;
}

使用场景示例

vue 复制代码
<template>
  <el-dialog>
    <div class="custom-content">需要定制的弹窗内容</div>
  </el-dialog>
</template>

<style scoped>
/* 修改Element Plus弹窗标题 */
:deep(.el-dialog__header) {
  background: #409eff;
}

/* 定制插槽内容样式 */
:slotted(.custom-content) {
  font-weight: bold;
}
</style>

注意事项

  1. 优先考虑组件props/custom class设计
  2. 避免过度使用样式穿透
  3. 注意样式优先级问题
  4. 使用scoped限定作用域
  5. 在Vue3中已废弃/deep/>>>语法

推荐结合CSS变量使用更灵活的样式定制方案:

css 复制代码
:deep(.child-component) {
  --theme-color: #42b983;
  color: var(--theme-color);
}
相关推荐
鹏程十八少4 小时前
破解Android悬浮窗遮挡无障碍服务难题:我在可见即可说上踩过的坑
android·前端·面试
Kapaseker4 小时前
前端已死...了吗
android·前端·javascript
m0_471199634 小时前
【自动化】前端开发,如何将 Jenkins 与 Gitee 结合实现自动化的持续集成(构建)和持续部署(发布)
前端·gitee·自动化·jenkins
w***95494 小时前
spring-boot-starter和spring-boot-starter-web的关联
前端
Moment4 小时前
富文本编辑器技术选型,到底是 Prosemirror 还是 Tiptap 好 ❓❓❓
前端·javascript·面试
xkxnq4 小时前
第二阶段:Vue 组件化开发(第 18天)
前端·javascript·vue.js
晓得迷路了4 小时前
栗子前端技术周刊第 112 期 - Rspack 1.7、2025 JS 新星榜单、HTML 状态调查...
前端·javascript·html
怕浪猫4 小时前
React从入门到出门 第五章 React Router 配置与原理初探
前端·javascript·react.js
jinmo_C++4 小时前
从零开始学前端 · HTML 基础篇(一):认识 HTML 与页面结构
前端·html·状态模式
鹏多多4 小时前
前端2025年终总结:借着AI做大做强再创辉煌
前端·javascript