为什么 /deep/ 现在不推荐使用?

  1. 兼容性和标准化问题
    /deep/ 是早期 Vue 项目中配合 scoped 样式使用的深度选择器,用于穿透组件的样式隔离(修改子组件或第三方组件的样式)。但它并非官方标准语法,而是某些预处理器(如 Less、Sass)和构建工具(如旧版 Webpack)的 "非标准实现",在不同环境中可能存在解析问题。

  2. Vue 3 的语法调整

    在 Vue 3 中,官方明确推荐使用 ::v-deep 替代 /deep/,因为 ::v-deep 是 Vue 框架定义的标准化深度选择器语法,兼容性更好,且在单文件组件(SFC)中更符合规范。

  3. CSS 原生穿透方案的兴起

    随着 CSS 原生 :deep() 伪类的普及(属于 CSS 嵌套规范的一部分),现代项目更倾向于使用标准的 :deep() 替代非标准的 /deep/::v-deep,因为它不依赖框架或预处理器,兼容性更广泛(现代浏览器和构建工具已普遍支持)。

替代方案推荐

如果要实现 "穿透 scoped 样式修改子组件样式",现在更推荐的写法是:

  1. Vue 3 及现代项目:使用 :deep()

    这是 CSS 原生语法(需配合支持 CSS 嵌套的环境,如 PostCSS 或现代浏览器),也是 Vue 3 官方推荐的写法:

复制代码
   /* 无需 /deep/,直接使用 :deep() */
   :deep(.ant-modal-content) {
     height: 100%;
     .ant-modal-body {
       height: calc(100% - 55px);
     }
     .ant-modal-footer {
       display: none;
     }
   }

Vue 2 项目:使用 ::v-deep

若仍在维护 Vue 2 项目,::v-deep 是比 /deep/ 更规范的替代方案,兼容性更稳定:

less

复制代码
   ::v-deep .ant-modal-content {
     /* 样式内容 */
   }
相关推荐
东东5162 小时前
基于ssm的网上房屋中介管理系统vue
前端·javascript·vue.js
harrain3 小时前
什么!vue3.4开始,v-model不能用在prop上
前端·javascript·vue.js
阿蒙Amon8 小时前
TypeScript学习-第7章:泛型(Generic)
javascript·学习·typescript
睡美人的小仙女1278 小时前
Threejs加载环境贴图报错Bad File Format: bad initial token
开发语言·javascript·redis
fanruitian8 小时前
uniapp android开发 测试板本与发行版本
前端·javascript·uni-app
rayufo8 小时前
【工具】列出指定文件夹下所有的目录和文件
开发语言·前端·python
RANCE_atttackkk8 小时前
[Java]实现使用邮箱找回密码的功能
java·开发语言·前端·spring boot·intellij-idea·idea
摘星编程9 小时前
React Native + OpenHarmony:Timeline垂直时间轴
javascript·react native·react.js
2501_9445255410 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 支出分析页面
android·开发语言·前端·javascript·flutter
jin12332210 小时前
React Native鸿蒙跨平台完成剧本杀组队详情页面,可以复用桌游、团建、赛事等各类组队详情页开发
javascript·react native·react.js·ecmascript·harmonyos