当前位置: 首页 > news >正文

为什么 /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 官方推荐的写法:

  2. /* 无需 /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 {/* 样式内容 */
    }
http://www.xdnf.cn/news/1301329.html

相关文章:

  • 稳定且高效:GSPO如何革新大型语言模型的强化学习训练?
  • Webpack详解
  • 思考:高速场景的行星轮混动效率如何理解
  • 解决Electron透明窗口点击不影响其他应用
  • 启动electron桌面项目控制台输出中文时乱码解决
  • 下载及交叉编译zlib库,记录
  • 解决ECharts图表上显示的最小刻度不是设置的min值的问题
  • 从源码到可执行文件:hello.c 的二进制之旅
  • 【Golang】:数据类型
  • Wi-Fi 与蜂窝网络(手机网络)的核心区别,以及 Wi-Fi 技术未来的发展方向
  • Redisson分布式锁实战指南:原理、用法与项目案例
  • GPT 解码策略全解析:从 Beam Search 到 Top-p 采样
  • 流处理、实时分析与RAG驱动的Python ETL框架:构建智能数据管道(上)
  • CPU、内存、存储:生信分析任务的服务器配置精要
  • 第20章 LINQ 笔记
  • 8.15网络编程——UDP和TCP并发服务器
  • 【数据分享】上市公司创新韧性数据(2007-2023)
  • 数据驱动测试提升自动化效率
  • 终极手撸cpu系列-详解底层原理-CPU硬核解剖:从0和1到 看透CPU逻辑设计内部原理,弄清楚现代多线程cpu工作原理
  • Microsoft Visual Studio常用快捷键和Windows系统常用快捷键的整理
  • Linux-地址空间
  • 开发避坑指南(27):Vue3中高效安全修改列表元素属性的方法
  • 【学习笔记】NTP服务客户端配置
  • Go语言中安全停止Goroutine的三种方法及设计哲学
  • 前瞻性技术驱动,枫清科技助力制造企业借助大模型完成生产力转化
  • zabbix部署问题后常见问题
  • 新手入门Makefile:FPGA项目实战教程(二)
  • 【CV 目标检测】②R-CNN模型
  • 【Redis】分布式系统的演化过程
  • MyBatis的基本用法和配置方式