vue3.2 中CSS 样式穿透
在Vue 3.2中,你可以使用::v-deep或/deep/选择器来实现CSS样式穿透。
::v-deep是Vue提供的伪元素选择器,它可以让样式穿透到子组件中。例如,假设你有一个父组件和一个子组件,你可以在父组件中使用::v-deep选择器来穿透到子组件中的元素:
<template>
<div>
<my-component>
<div class="my-class">Hello World</div>
</my-component>
</div>
</template>
<style scoped>
::v-deep .my-class {
color: red;
}
</style>
在上面的例子中,::v-deep选择器会穿透到my-component组件中,然后将.my-class选择器应用到子组件中的元素上。
另外,你也可以使用/deep/选择器来实现样式穿透。/deep/选择器与::v-deep选择器的作用相同,但是它是一个已弃用的选择器,不建议使用。
需要注意的是,使用样式穿透可能会导致出现样式冲突的问题,因此建议在必要时才使用。同时,为了避免全局样式的影响,建议在样式中使用scoped属性。
Vue2 中在 scoped 中修改子组件或者组件库中的组件样式,改不了的情况下,就可以用样式穿透,不管是 Less 还是 SASS 都是用 /deep/ .class {} 来做样式穿透,而 Vue3 中就不支持 /deep/ 的写法了,换成 :deep(.class)
<style lang="scss" scoped>
// 这样写不生效的话
.el-form {
.el-form-item { ... }
}
// Vue2 中这样写
/deep/ .el-form {
.el-form-item { ... }
}
// Vue3 中这样写
:deep(.el-form) {
.el-form-item { ... }
}
</style>
// 别再这样加一个没有 scoped 的 style 标签了,全都加到全局上去了
// <style lang="scss">
// .el-form {
// .el-form-item { ... }
// }
// </style>
CSS 绑定 JS 变量
就是 CSS 中可以使用 JS 的变量来赋值,如下
<template>
<div class="name">沐华</div>
</template>
<script setup>
import { ref } from "vue"
const str = ref('#f00') // 红色
</script>
<style scoped lang="scss">
.name {
background-color: v-bind(str); // JS 中的色值变量 #f00 就赋值到这来了
}
</style>

相关推荐
-
PHP8种变量类型的详细讲解2025-02-22 00:32:24
-
php+apache 和 php+nginx的区别2025-02-22 00:21:27
-
PHP:与workerman结合实现定时任务2025-02-22 00:15:57
-
Nginx的Rewrite规则与实例2025-02-22 00:15:39
-
MySql中身份证字段的简单脱敏介绍2025-02-22 00:15:36