Как использовать ::v-deep(<inner-selector>) в vue?
Я пытаюсь применить существующий класс стиля к дочернему элементу, который будет загружен с использованием v-html, поскольку /deep/ и >>> устарели, я пробовал использовать :: v-deep в vue.
<template>
<div v-else v-html="childHtml" class="parent-class"></div>
</template>
<style scoped>
.parent-class ::v-deep .child-class {
border: unset;
border-radius: 2px;
margin: 0 auto;
margin-bottom: 2%;
background-color: #fff;
box-sizing: border-box;
zoom: 70%;
}
</style>
Но компилятор vue говорит, что использование *::v-deep в качестве комбинатора устарело. Вместо этого используйте::v-deep(). (с использованием Vue 3.0.0-beta.1)
Как использовать::v-deep() и избавиться от этой ошибки компиляции??
пожалуйста, помогите, заранее спасибо
1 ответ
Вы можете попробовать и использовать >>> .class-i-want-deep{ /// }
если вы не используете sass/scss. Документы от vue-loader здесь.
Что касается сообщения об ошибке, то здесь говорится:
"Использование *::v-deep в качестве комбинатора устарело. Вместо этого используйте::v-deep(). (с использованием Vue 3.0.0-beta.1)"
Итак, похоже, что ваш синтаксис для ::v-deep
is here больше не разрешено в Vue 3. Попробуйте использовать new::v-deep(), я не могу найти документацию специально для этого. Обновление: похоже, использование::v-deep() с 3.0 работает для OP. Еще не воспроизвел.