Как использовать ::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-deepis here больше не разрешено в Vue 3. Попробуйте использовать new::v-deep(), я не могу найти документацию специально для этого. Обновление: похоже, использование::v-deep() с 3.0 работает для OP. Еще не воспроизвел.

Другие вопросы по тегам