mirror of https://github.com/ElemeFE/element
124 lines
5.4 KiB
Markdown
124 lines
5.4 KiB
Markdown
![]() |
## Thème
|
||
|
Element utlise le style BEM pour le CSS afin que vous puissiez écraser les règles prédéfinies facilement. Mais si vous avez besoin de remplacer des styles à une plus grande échelle , e.g. changer le thème de bleu à orange ou vert, les modifier une par une serait fastidieux. Nous fournissons trois méthodes pour changer les variables de style.
|
||
|
|
||
|
### Changer la couleur du thème
|
||
|
Si vous avez juste besoin de changer la couleur du thème, le [générateur de thème en ligne](https://elementui.github.io/theme-chalk-preview/#/en-US) est recommandé. La couleur du thème d'Element est un bleau clair et agréable. En le changeant, vous rendez Element visuellement plus adapté à vos projets.
|
||
|
|
||
|
Le site précédent vous permet de visualiser et de télécharger un nouveau thème immédiatement (pour un importer un nouveau thème, référez-vous à la partie 'Importer un thème personnalisé' or 'Importer un thème de composant à la demande' de cette section).
|
||
|
|
||
|
### Mettre à jour les variables SCSS de votre projet
|
||
|
`theme-chalk` est écrit en SCSS. Si votre projet utilises SCSS, vous pouvez changer directement les variables d'Élément. Créez un nouveau fichier, e.g. `element-variables.scss`:
|
||
|
|
||
|
```html
|
||
|
/* couleur du thème */
|
||
|
$--color-primary: teal;
|
||
|
|
||
|
/* chemin vers le fichier de police, requis */
|
||
|
$--font-path: '~element-ui/lib/theme-chalk/fonts';
|
||
|
|
||
|
@import "~element-ui/packages/theme-chalk/src/index";
|
||
|
```
|
||
|
|
||
|
Puis dans le fichier d'entrée, importez ce style au lieu de celui d'Element:
|
||
|
```JS
|
||
|
import Vue from 'vue'
|
||
|
import Element from 'element-ui'
|
||
|
import './element-variables.scss'
|
||
|
|
||
|
Vue.use(Element)
|
||
|
```
|
||
|
|
||
|
:::tip
|
||
|
Il est obligatoire de remplacer le chemin du fichier de police.
|
||
|
:::
|
||
|
|
||
|
### Outil de thème CLI
|
||
|
Si votre projet n'utilise pas SCSS, vous pouvez personnaliser le thème en utilisant notre outil en ligne de commande:
|
||
|
|
||
|
#### <strong>Installation</strong>
|
||
|
Installez le générateur de thème de manière globale ou locale. Une installation locale est recommandé afin que les personnes clonant votre dépôt bénéficient d'une installation automatique via npm.
|
||
|
```shell
|
||
|
npm i element-theme -g
|
||
|
```
|
||
|
|
||
|
Installer ensuite le thème chalk depuis npm ou GitHub.
|
||
|
```shell
|
||
|
# Via npm
|
||
|
npm i element-theme-chalk -D
|
||
|
|
||
|
# Via GitHub
|
||
|
npm i https://github.com/ElementUI/theme-chalk -D
|
||
|
```
|
||
|
|
||
|
#### <strong>Initialisation d'un fichier de variable</strong>
|
||
|
Après l'installation des paquets ci-dessus, une commande appellée `et` devient disponible dans le CLI (si les paquets sont installés localement, utilisez `node_modules/.bin/et` à la place). Utilisez `-i` pour intialiser le fichier de variables, `element-variables.scss` par défaut. Vous pouvez spécifier n'importe quel dossier comme sortie.
|
||
|
|
||
|
```shell
|
||
|
et -i [nom du fichier]
|
||
|
|
||
|
> ✔ Generator variables file
|
||
|
```
|
||
|
|
||
|
Dans `element-variables.scss` vous trouverez toutes les variables utilisées pour le style d'Element, définies en SCSS. Voici un snippet:
|
||
|
|
||
|
```css
|
||
|
$--color-primary: #409EFF !default;
|
||
|
$--color-primary-light-1: mix($--color-white, $--color-primary, 10%) !default; /* 53a8ff */
|
||
|
$--color-primary-light-2: mix($--color-white, $--color-primary, 20%) !default; /* 66b1ff */
|
||
|
$--color-primary-light-3: mix($--color-white, $--color-primary, 30%) !default; /* 79bbff */
|
||
|
$--color-primary-light-4: mix($--color-white, $--color-primary, 40%) !default; /* 8cc5ff */
|
||
|
$--color-primary-light-5: mix($--color-white, $--color-primary, 50%) !default; /* a0cfff */
|
||
|
$--color-primary-light-6: mix($--color-white, $--color-primary, 60%) !default; /* b3d8ff */
|
||
|
$--color-primary-light-7: mix($--color-white, $--color-primary, 70%) !default; /* c6e2ff */
|
||
|
$--color-primary-light-8: mix($--color-white, $--color-primary, 80%) !default; /* d9ecff */
|
||
|
$--color-primary-light-9: mix($--color-white, $--color-primary, 90%) !default; /* ecf5ff */
|
||
|
|
||
|
$--color-success: #67c23a !default;
|
||
|
$--color-warning: #e6a23c !default;
|
||
|
$--color-danger: #f56c6c !default;
|
||
|
$--color-info: #909399 !default;
|
||
|
|
||
|
...
|
||
|
```
|
||
|
|
||
|
#### <strong>Modifier les variables</strong>
|
||
|
Éditer `element-variables.scss`, e.g. en changeant la couleur du thème pour du rouge:
|
||
|
```CSS
|
||
|
$--color-primary: red;
|
||
|
```
|
||
|
|
||
|
#### <strong>Générer le thème</strong>
|
||
|
Après avoir sauvegarder le fichier de variables, utilisez `et` pour générer le thème. Vous pouvez activer le mode `watch` en ajoutant le paramètre `-w`. Si vous avez choisi le chemin du fichier de sortie, il vous faudra ajouter le paramètre `-c` avec le nom du fichier:
|
||
|
```shell
|
||
|
et
|
||
|
|
||
|
> ✔ build theme font
|
||
|
> ✔ build element theme
|
||
|
```
|
||
|
|
||
|
#### <strong>Importer le thème</strong>
|
||
|
Par défaut le thème généré est placé dans `./theme`. Vous pouvez spécifier le dossier de sortie grâce à `-o`. Importer votre propre thème se fait de la même manière qu'importer le thème par défaut:
|
||
|
|
||
|
```javascript
|
||
|
import '../theme/index.css'
|
||
|
import ElementUI from 'element-ui'
|
||
|
import Vue from 'vue'
|
||
|
|
||
|
Vue.use(ElementUI)
|
||
|
```
|
||
|
|
||
|
#### <strong>Importer le thème d'un composant sur demande</strong>
|
||
|
Si vous utilisez `babel-plugin-component` pour les imports sur demande, modifiez `.babelrc` et spécifiez `styleLibraryName` avec le chemin où votre thème est localisé relativement à `.babelrc`. N'oubliez pas que `~` est requis:
|
||
|
```json
|
||
|
{
|
||
|
"plugins": [["component", [
|
||
|
{
|
||
|
"libraryName": "element-ui",
|
||
|
"styleLibraryName": "~theme"
|
||
|
}
|
||
|
]]]
|
||
|
}
|
||
|
```
|
||
|
|
||
|
Si vous n'êtes pas familier avec `babel-plugin-component`, référez-vous à la page <a href="./#/fr-FR/component/quickstart">Guide</a>. Pour plus d'informations, jetez un oeil au [dépôt du projet](https://github.com/ElementUI/element-theme) de `element-theme`.
|