sass 中使用/deep/报错(已解决)

vue3中使用element plus,想要覆盖组件的样式,想到了/deep/样式穿透,样式一直不生效,代码如下:

<style scoped lang="sass">
.main_wrapper
  padding: 0 53px
  position: relative
  top: -20px
  >>> .el-tabs__item
    height: 30px
    line-height: 30px
    color: #fff!important
</style>

上边的写法不会报错,但是也不会生效。改用下面的方式:

<style scoped lang="sass">
.main_wrapper
  padding: 0 53px
  position: relative
  top: -20px
  /deep/ .el-tabs__item
    height: 30px
    line-height: 30px
    color: #fff!important
</style>

好码,这样就报错了,如下:
SassError: expected selector

看来sass不支持这个选择器。

解决方法:

尝试用 ::v-deep 替换 /deep/ ,成功解决了问题。

<style scoped lang="sass">
.main_wrapper
  padding: 0 53px
  position: relative
  top: -20px
  ::v-deep .el-tabs__item
    height: 30px
    line-height: 30px
    color: #fff!important
</style>

但是后续发现,控制台给出了这样的提示:
::v-deep usage as a combinator has been deprecated. Use :deep(<inner-selecto

意思上边的语法已经废弃了,需要把::v-deep后边的选择器放在一个括号了:

<style scoped lang="sass">
.main_wrapper
  padding: 0 53px
  position: relative
  top: -20px
  ::v-deep(.el-tabs__item)
    height: 30px
    line-height: 30px
    color: #fff!important
</style>

到此,警告已经消失不见了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值