Skip to content

Transformator Compile Class

Compilează un grup de clase într-o singură clasă. Inspirat de modul de compilare al Windi CSS și problema #948 de către @UltraCakeBakery.

Instalare

bash
pnpm add -D @unocss/transformer-compile-class
bash
yarn add -D @unocss/transformer-compile-class
bash
npm install -D @unocss/transformer-compile-class
bash
bun add -D @unocss/transformer-compile-class
ts
import transformerCompileClass de la '@unocss/transformer-compile-class'
import { defineConfig } de la 'unocss'

export default defineConfig({
  // ...
  transformers: [
    transformerCompileClass(),
  ],
})

TIP

Acest preset este inclus în pachetul unocss, îl puteți importa și de acolo:

ts
import { transformerCompileClass } de la 'unocss'

Utilizare

Adăugați :uno: la începutul șirurilor de clase pentru a le marca pentru compilare.

De exemplu:

html
<div class=":uno: text-center sm:text-left">
  <div class=":uno: text-sm font-bold hover:text-red" />
</div>

Va fi compilat în:

html
<div class="uno-qlmcrp">
  <div class="uno-0qw2gr" />
</div>
css
.uno-qlmcrp {
  text-align: center;
}
.uno-0qw2gr {
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 700;
}
.uno-0qw2gr:hover {
  --un-text-opacity: 1;
  color: rgb(248 113 113 / var(--un-text-opacity));
}
@media (min-width: 640px) {
  .uno-qlmcrp {
    text-align: left;
  }
}

Opțiuni

Puteți configura șirul de trigger și prefixul pentru compilare a clasei cu opțiunile. Referiți-vă la tipurile pentru detalii.

Instrumente

ESLint

Există o regulă eslint pentru a impune transformatorul de compilare a clasei pe întregul proiect: @unocss/enforce-class-compile

Utilizare:

json
{
  "plugins": ["@unocss"],
  "rules": {
    "@unocss/enforce-class-compile": "warn"
  }
}

Licență

Released under the MIT License.