CSS модули

CSS модули — это популярная система для модульности и компоновки CSS. vue-loader предоставляет первоклассную интеграцию с CSS модулями как возможную альтернативу эмулируемого локального (scoped) CSS.

Использование

Во-первых, CSS модули нужно явно включить, передав опцию modules: true в css-loader:

// webpack.config.js
{
  module: {
    rules: [
      // ... другие правила опущены
      {
        test: /\.css$/,
        use: [
          'vue-style-loader',
          {
            loader: 'css-loader',
            options: {
              // включаем CSS модули
              modules: true,
              // настраиваем генерируемое имя класса
              localIdentName: '[local]_[hash:base64:8]'
            }
          }
        ]
      }
    ]
  }
}

Затем, добавляем атрибут module к тегу секции <style>:

<style module>
.red {
  color: red;
}
.bold {
  font-weight: bold;
}
</style>

Атрибут module подскажет Vue Loader о необходимости внедрить CSS модуль в компонент в качестве вычисляемого свойства с именем $style. Вы можете использовать его в шаблонах для динамического добавления классов:

<template>
  <p :class="$style.red">
    Текст должен быть красным
  </p>
</template>

Поскольку это вычисляемое свойство, оно будет работать с объектом/массивом в :class:

<template>
  <div>
    <p :class="{ [$style.red]: isRed }">
      Буду ли я красным?
    </p>
    <p :class="[$style.red, $style.bold]">
      Красный и жирный
    </p>
  </div>
</template>

Вы также можете получить доступ в JavaScript:

<script>
export default {
  created () {
    console.log(this.$style.red)
    // -> "red_1VyoJ-uZ"
    // идентификатор генерируется на основе имени файла и className.
  }
}
</script>

Обратитесь к спецификации CSS-модулей для получения информации о глобальных исключениях и композиции.

Опциональное использование

Если вы хотите использовать CSS модули только в некоторых компонентах Vue, вы можете использовать правило oneOf и проверять наличие строки module внутри resourceQuery:

// webpack.config.js -> module.rules
{
  test: /\.css$/,
  oneOf: [
    // это соответствует `<style module>`
    {
      resourceQuery: /module/,
      use: [
        'vue-style-loader',
        {
          loader: 'css-loader',
          options: {
            modules: true,
            localIdentName: '[local]_[hash:base64:5]'
          }
        }
      ]
    },
    // это соответствует простому `<style>` или `<style scoped>`
    {
      use: [
        'vue-style-loader',
        'css-loader'
      ]
    }
  ]
}

Использование с пре-процессорами

CSS модули могут быть использованы вместе с другими пре-процессорами:

// webpack.config.js -> module.rules
{
  test: /\.scss$/,
  use: [
    'vue-style-loader',
    {
      loader: 'css-loader',
      options: { modules: true }
    },
    'sass-loader'
  ]
}

Указание имени внедряемого модуля

У вас может быть несколько тегов <style> в одном компоненте *.vue. Во избежание перезаписи внедряемых стилей вы можете указать имя внедряемого вычисляемого свойства в значении атрибута module:

<style module="a">
  /* идентификатор будет внедрён как a */
</style>

<style module="b">
  /* идентификатор будет внедрён как b */
</style>