Метод определения области действия и проникновения в Vue

Vue.js

Происхождение области действия

У CSS всегда была неприятная проблема с областью действия: даже при модульном программировании при импорте CSS в js соответствующего модуля CSS по-прежнему глобальный. Чтобы избежать загрязнения стилей CSS, в vue вводится понятие области видимости.

В теге стиля в файле vue есть специальный атрибут: scoped. Когда тег стиля имеет атрибут scoped, его стили CSS применяются только к текущему компоненту. При установке этого свойства стили между компонентами не загрязняют друг друга. Если все теги стиля в проекте имеют область действия, это эквивалентно реализации модуляризации стилей.

Но как эти стили достигаются, не влияя друг на друга?

Принцип охвата

Scoped в vue обеспечивает уникальность (и эта работа достигается за счет перевода PostCSS) путем добавления уникального и неповторяющегося тега: data-v-hash к структуре DOM и стилям CSS, а также обеспечивает приватизацию стилей и модульность Цель.

Суммируйте три правила рендеринга области видимости:

  1. Добавьте неповторяющийся атрибут данных (например, data-v-19fca230) в узел HTML DOM, чтобы указать его уникальность.
  2. Добавьте селектор атрибутов данных текущего компонента (например, [data-v-19fca230]) в конец каждого селектора css (скомпилированный сгенерированный оператор css), чтобы приватизировать стиль
  3. Если компонент содержит другие компоненты, только атрибут данных текущего компонента будет добавлен к самой внешней метке других компонентов.

Последний каштан. Перед переводом:

<style lang="scss" scoped>
    .test {
        background: blue;
        span{
            color:red;
        }
    }
</style>
<template>
    <div class="test">
        <span>hello world !</span>
    </div>
</template>

После перевода:

<style lang="css">
    .test[data-v-ff86ae42] {
        background: blue;
    }
    .test span[data-v-ff86ae42]{
        color: red;
    }
</style>
<template>
    <div class="test" data-v-ff86ae42>
        <span data-v-ff86ae42>hello world !</span>
    </div>
</template>

Видно, что PostCSS добавляет уникальный динамический атрибут data-v-xxxx ко всем доменам в компоненте, а затем добавляет соответствующий селектор атрибутов в селектор CSS для выбора домена в компоненте. dom, содержащий этот атрибут, — внутренний dom компонента, чтобы добиться эффекта «модульности стиля».

Проникновение ограничено

Однако при работе над проектом вы столкнетесь с такой проблемой, то есть, если вы ссылаетесь на сторонний компонент, вам нужно изменить стиль стороннего компонента локально в компоненте, и вы не хотите чтобы удалить атрибут scoped, чтобы вызвать загрязнение стиля между компонентами. Итак, каковы решения?

  1. Не используйте scoped для пропуска (лично не рекомендую)
  2. Дважды используйте тег стиля в шаблоне:
<style lang="scss">
    /*添加要覆盖的样式*/
</style>
<style lang="scss" scoped>
    /* local styles */
</style>
<!--vue官网中提到:一个 .vue 文件可以包含多个style标签。所以上面的写法是没有问题的。-->
  1. Уровень проникновения >>>
<template>
  <div class="box">
    <dialog></dialog>
  </div>
</template>
<!--使用 >>>或者 /deep/ 操作符(Sass 之类的预处理器无法正确解析 >>>,可以使用/deep/)-->
<style lang="scss" scoped>
.box {
  /deep/ input {
    width: 166px;
    text-align: center;
  }
}
</style>
或者
<style lang="scss" scoped>
.box >>> input {
    width: 166px;
    text-align: center;
  }
}
</style>

Надеюсь, это поможет вам, у кого такая же проблема, спасибо!