vue中各种deep的区别解析
一共,::v-deep、::deep 和 :deep(),>>>,/deep/
从Vue 3开始,推荐使用 ::deep 而不是 ::v-deep
1. ::v-deep
::v-deep 是 Vue 2 中引入的深度选择器,在 Vue 3 中仍然可用,但不再是推荐的写法。它用于穿透作用域,将样式应用到子组件的元素上。
示例
<template> <div class="parent"> <ChildComponent /> </div> </template> <script setup> import ChildComponent from './ChildComponent.vue'; </script> <style scoped> .parent ::v-deep .child-class { color: red; } </style>
2. ::deep
::deep 是 Vue 3 中推荐的深度选择器。它与 ::v-deep 功能相同,但语法更简洁。
示例
<template> <div class="parent"> <ChildComponent /> </div> </template> <script setup> import ChildComponent from './ChildComponent.vue'; </script> <style scoped> .parent ::deep .child-class { color: red; } </style>
3. :deep()
:deep() 是 Vue 3 中推荐的另一种深度选择器。它是一个伪类,可以嵌套在其他选择器中使用,提供了更灵活的语法。
示例
<template> <div class="parent"> <ChildComponent /> </div> </template> <script setup> import ChildComponent from './ChildComponent.vue'; </script> <style scoped> .parent :deep(.child-class) { color: red; } </style>
4 . >>>
在早期版本的Vue.js中,>>> 也被用来作为深度选择器。它的用法与 ::v-deep 类似,但是现在已经被 ::v-deep 或 ::deep 所取代。
示例:
.parent-class >>> .child-class { color: blue; }
5. /deep/
/deep/ 也是早期Vue.js版本中的一个深度选择器。不过,随着Vue 2.6.0的发布,官方建议使用 ::v-deep 替代 /deep/。在某些情况下,特别是在使用某些构建工具或配置时,/deep/ 可能仍然有效,但并不推荐继续使用。
示例:
.parent-class /deep/ .child-class { color: green; }
到此这篇关于vue中各种deep的区别的文章就介绍到这了,更多相关vue deep区别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Vue之Element级联选择器多选传值以及回显方式(树形结构)
这篇文章主要介绍了Vue之Element级联选择器多选传值以及回显方式(树形结构),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2023-07-07解决vue组件没显示,没起作用,没报错,但该显示的组件没显示问题
这篇文章主要介绍了解决vue组件没显示,没起作用,没报错,但该显示的组件没显示问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-09-09
最新评论