vue3项目使用element plus中的el-drawer抽屉组件,想自定义.el-drawer__header和.el-drawer__body的样式,使用:deep()为啥不起作用呢?
比如想调整el-drawer抽屉组件的默认标题下外边距及标题字体颜色,和内容区域的默认内边距宽度
代码如下图:
环境版本如下图:
其他如el-tabs等组件,使用:deep自定义重写样式都是可以的,为啥到了这个el-drawer组件就不行了呢?
vue3项目使用element plus中的el-drawer抽屉组件,想自定义.el-drawer__header和.el-drawer__body的样式,使用:deep()为啥不起作用呢?
比如想调整el-drawer抽屉组件的默认标题下外边距及标题字体颜色,和内容区域的默认内边距宽度
代码如下图:
环境版本如下图:
其他如el-tabs等组件,使用:deep自定义重写样式都是可以的,为啥到了这个el-drawer组件就不行了呢?
根据上面回答这样做试出了效果
先给.el-drawer套个div,class=box-drawer
再给.el-drawer定义个class=remark-drawer
.box-drawer {
&:deep(.el-drawer.remark-drawer) {
width: 30vw !important;
.el-drawer__header {
margin-bottom: 0px !important;
padding: 1vh 1vw !important;
}
.el-drawer__body {
padding: 0px 1vw !important;
}
}
}
看下是不是这个原因,组件要有个根节点才生效
https://blog.csdn.net/wangyining070205/article/details/127156652
6 回答2.9k 阅读✓ 已解决
8 回答4.7k 阅读✓ 已解决
6 回答3.4k 阅读✓ 已解决
6 回答2.3k 阅读
5 回答6.3k 阅读✓ 已解决
3 回答2.4k 阅读✓ 已解决
3 回答1.4k 阅读✓ 已解决
这是 Vue 的缺陷。
当子组件使用 Teleport 或者 Fragment 时,不会将当前的 scopedId (data-v-xxx) 放置在组件的根元素(或者是 $attr 绑定的元素中)。
所以,当你在父组件使用 scoped css 时,样式不会正确的匹配。
比如父组件声明了:
<style scoped>.custom-teleport { xxx }</style>
会被编译成:
.custom-teleport[data-v-xxx] {xxx}
但是,子组件并没有 data-v-xxx 这个属性,因此样式显示错误。
解决方案:
参考代码: