CSS et introduction à SASS

Tags :
  • MON
  • 2022-2023
  • temps 1
  • CSS
  • SASS
Auteurs :
  • Timothée Bermond

Les bases du CSS et introduction à SASS

Les bases du CSS

J'ai tout d'abord commencé par suivre la partie sur le CSS de cette formation openclassrooms.

Le CSS permet de faire la mise en forme son site (couleur du texte, police, mise en page,...).

Mon POK sans css. Mon POK avec css.

Le CSS peut-être écrit dans un fichier .css (recommandé), dans l'en-tête du fichier html à l'aide d'une balise style ou directement dans les balises (non recommandé). Utiliser un fichier .css permet de facilement généraliser les propriétés à toutes nos pages html sans avoir à faire des copié-collé.

Pour appliquer un style nous pouvons sélectionner :

Pour ce faire on écrit le nom de la balise / classe / id puis on ajoute entre acolades les propriétés que l'on veut appliquer.

balise{
  propriété1: valeur1;
  propriété2: valeur2;
}

Pour chaque propriété on doit indiquer une valeur.

On peut égalemement appliquer un style à plusieurs balises en les séparant d'une virgule.

balise1, balise2{
  propriété1: valeur1;
  propriété2: valeur2;
}

Formater du texte

Il est possible de modifier de nombreuses caractéristiques du texte.

La taille

Il est possible de modifier la taille du texte avec la propriété font-size. On peut indiquer une taille absolue ou une taille relative.

p{
  font-size: 14px;
}
p{
  font-size: 1.8em;
}

La police

Pour modifier la police il faut utiliser la propriété font-family suivi d'au moins une police. Le mieux est d'indiquer au moins 4 polices (séparées par des virgules) au cas où l'internaute n'aurait pas la 1ère police. (le navigateur essaiera tout d'abord d'utiliser a police1, s'il ne l'a pas il essaiera la police2, etc...)

Italique

Pour mettre en italique on utilise la propriété font-style et la valeur italic.

Gras

Pour mettre en gras on utilise la propriété font-weight et la valeur bold.

Souligné

Pour souligner ou décorer le texte on utilise la propriété text-decoration et les valeurs :

On peut également indiquer la valeur none si on veut annuler une des propriétés précédentes.

L'alignement

Il est possible d'appliquer tous les alignements connus avec la propriété text-align et les valeurs :

Ajouter de la couleur et un fond

Couleur du texte

On peut modifier la couleur du texte avec la propriété color. Pour les valeurs il y a plusieurs choix possibles :

Couleur de fond

Pour cela on utilise la propriété background-color et les mêmes valeurs que précédemment.

Image de fond

Pour cela on utilise la propriété background-image et en valeur url("nom_de_l_image.webp").

Avec la propriété background-attachment on peut décider :

Il est également possible de répéter ou non l'image de fond avec la propriété background-repeat.

Ou encore d'indiquer la position de l'image de fond avec la propriété background-position.

Transparence

Il est possible de jouer avec les niveaux de transparence des éléments avec la propriété opacity qui prend une valeur entre 0 et 1 (1:opaque, 0:transparent) ou en utilisant la notation RGBa qui consiste à ajouter une valeur comprise entre 0 et 1 à la notation RGB.

Créez des bordures et des ombres

Bordures standards

Pour modifier l'apparence de la bordure on utilise la propriété border qui peut prendre jusqu'à 3 valeurs :

Il est également possible de ne sélectionner qu'une bordure avec les propriétés :

On peut aussi arrondir les bordures avec la propriété border-radius et on indique l'importance de l'arrondi en pixels.

Les ombres

Il est possible d'ajouter l'ombre des boites avec la propriété box-shadow qui prend 4 valeurs :

  1. Le décalage horizontzal
  2. Le décalage vertical
  3. L'adoucissement du dégradé.
  4. La couleur de l'ombre.

Il est également possible d'ajouter la valeur inset qui place l'ombre à l'intérieur du bloc.

On peut aussi ajouter l'ombre du texte avec la propriété text-shadow qui prend les mêmes valeurs que box-shadow.

Apparences dynamiques

Il est possible de modifier l'apparence du texte :

Structurer son site

Les balises structurantes

Des balises ont été introduites pour structurer les pages :

Ce qui donne a peu près :

Flexbox

C'est la technique que j'ai principalement utilisé pour la mise en page de mon POK.

Le principe de la mise en page est simple : On définit un conteneur dans lequel on place des éléments. Le conteneur est une balise HTML et les éléments sont d'autres balises HTML à l'intérieur de cette balise :

<div id="conteneur">
  <div class="element 1">Element</div>
  <div class="element 2">Element</div>
  <div class="element 3">Element</div>
</div>

Il faut ensuite ajouter la valeur flex à la propriété display du conteneur.

On peut maintenant modifier la direction avec la propriété flex-direction qui peut prendre les valeurs suivantes :

Afin de permettre aux éléments d'aller à la ligne si il n'y a plus de place il faut utiliser la propriété flex-wrap.

On peut ensuite aligner les éléments selon l'axe principal avec la propriété justify-content qui peut prendre différentes valeurs :

Mais on peut également aligner les éléments sur l'axe secondaire avec la propriété align-items qui peut prendre différentes valeurs : Il est possible d'aligner un seul élément sur l'axe secondaire avec la propriété align-self.

La propriété order permet de changer l'ordre des éléments du conteneur.

Enfin la propriété flex peut autoriser les éléments à occuper plus ou moins d'espace restant. Par exemple :

.element:nth-child(1)
{
    flex: 2;
}
.element:nth-child(2)
{
    flex: 1;
}

permet à l'élément 1 de grossir 2 fois plus que l'élément 1.

Il existe également d'autres manières de structurer les pages que je n'ai pas étudier durant ce MON.

Simplification du CSS avec Sass

Dans une deuxième partie j'ai suivi cette autre formation openclassrooms.

Structure du CSS

Il est très facile de se retrouver avec des fichiers .css brouillons et il devient alors très difficile et surtout long pour rien de modifier l'apparence de certaines parties de son site. C'est pourquoi il est important d'avoir un fichier .css bien structuré afin de gagner en efficacité.

Principe du DRY

Le principe DRY, signifiant "Don't Repeat Yourself", est très important : il ne faut pas que l'on retrouve des règles qui se répètent. Dans mon POK par exemple on peut retrouver la répétion de la même règle pour deux balises différentes.

#div_choix3{
    display: none;
}

#div_choix4{
    display: none;
}

J'ai donc ajouté une règle .div_choix-hide que j'applique à mes deux div en ajoutant div_choix-hide à leur classe. On passe donc de ceci :

<div id="div_choix4" class="div_choix">

A ceci :

<div id="div_choix4" class="div_choix div_choix-hide">

J'ai fusionné mes deux règles redondantes en une seule :

.div_choix-hide{
    display: none;
}

Ce qui me permet d'avoir un codebase plus facile à maintenir.

Je l'ai appliqué à mon POK et suis passé d'un fichier .css de plus de 300 lignes à un fichier de moins de 200 lignes.

Spécificité

Définition de la documentation MDN :

La spécificité est la manière dont le navigateur décide quelle règle s’applique si plusieurs règles ont des sélecteurs différents, mais peuvent quand même s’appliquer au même élément.

C'est super compliqué à expliquer et je vais juste vous embrouiller donc allez checker vous même sur le cours où c'est très bien expliqué.

BEM

BEM est une convention CSS qui permet de rapidement s'y retrouver dans son code sans avoir à chercher des heures à quoi sert tel ou tel élément.

BEM est l'acronyme de bloc, élément, modificateur.

Comment ça fonctionne?

Tout d'abord, il faut construire des blocs, càd un composant qui est autonome et peut fonctionner indépendamment du reste de la page. Par exemple, dans un portfolio, si on supprimait tout sauf le titre d'un projet il ne deviendrait qu'un bout de texte isolé. Alors que si on prend l'aperçu entier du projet (titre, image, description) là ça à du sens, on a donc un bloc que l'on va nommer en décrivant sa fontion : .apercu-proj et auquel on va assigner les règles spécifiques à ce bloc. Ensuite, on va nommer tous les éléments de ce bloc selon une nomenclature particulière : bloc_parent__fonction_élément. Ici, pour le titre on obtiendrait : .apercu-proj__titre. Enfin, pour des modifications spécifiques à un bloc ou un élément on va ajouter un modificateur. Là encore, il y a une nomenclature spéciale : bloc/élément_modifié--style_modificateur. Dans notre cas, si on veut mettre un fond vert ça donnerait : apercu-projet--vert

Sass

Sass est un préprocesseurs css, càd un outil qui permet de rédiger son code de manière plus cohérente visuellement. Il est possible d'écrire du Sass dans des fichiers .sass ou .scss. La syntaxe est légèrement différente mais reste quand même très proche.

Dans ce MON nous allons nous concentrer sur les fichiers .scss.

Grâce à Sass, il est possible d'utiliser le nesting, càd l'imbrication des sélécteurs. Au lieu d'écrire :

ul {
  list-style: none;
  text-align: right;
}

ul li {
  display: inline;
  font-size: 3rem;
  color: #D6FFF5;
}

On écrit :

ul {
  list-style: none;
  text-align: right;
  li {
      display: inline;
      font-size: 3rem;
      color: #D6FFF5;
  }
}

Attention à ne pas créer des sélecteurs trop spécifiques.

On pourrait donc être tenté de reproduire une copie conforme de la structure de notre HTML. Cela n'est pas une bonne idée car on va se retrouver avec des sélécteurs de haute spécificité qui seront très durs à modifier.

Utiliser des sélécteurs BEM avec Sass

On peut fusionner la méthodologie BEM et le nesting de Sass.

Pour cela on utilise les & ce qui nous permet d'être plus clair visuellement et de ne pas avoir à répeter le nom des blocs ou des éléments :

.block{
  background-color: #15DEA5;
  &__element {
      color: #fff;
        &--modifier {
            background-color: #001534;
  }
  }
}

Ce qui nous donne en CSS compilé :

.block {
  background-color: #15DEA5;
}

.block__element {
  color: #fff;
}

.block__element--modifier {
  background-color: #001534;
}

Améliorer la maintenabilité du code avec les variables Sass

Afin de pouvoir rapidement modifier une valeur qui apparait de nombreuses fois dans le CSS, il est possible d'utiliser les variables Sass. Par exemple, si l'on retrouve un grand nombre de fois la couleur vert menthe dans notre fichier, il est possible d'écrire $color-primary: #15DEA5 au début de votre fichier .scss et puis de remplacer tous les #15DEA5 par $color-primary dans le reste du fichier. Comme ça si l'on décide de changer la couleur principale de notre site il suffit de changer le code hexadécimal et tous les éléments changeront de couleur plutôt que de devoir les changer 1 à 1.

Nommer la variable en fonction de son rôle

On pourrait donc être tenté de nommer la variable #mint (vert menthe) mais si l'on change de couleur par du bleu alors il faudrait soit changer tous #mint du fichier soit juste changer le $mint: #15DEA5 au début mais cela créérait une confusion car la couleur ne serait plus vert menthe mais bleu.

Il existe 8 types de variables dans Sass:

Les mixins Sass

Les mixins fonctionnent un peu comme une variable sauf qu'elles stockent des blocs entiers de code. C'est donc très pratique pour stocker des ensembles de règles CSS que l'on utilise fréquemment.

@mixin mixin-name {
  css-property: value;
}

Par exemple, si l'on veut ajouter des ombres à de nombreux textes on peut créer une mixin :

@mixin heading-shadow{
  text-shadow: .55rem .55rem #15DEA5;
}

Et puis l'ajouter dans notre sélecteur :

.form {
  &__heading {
      @include heading-shadow;
  }
}

Il est également possible d'ajouter des arguments à nos mixins :

@mixin heading-shadow($colour){
  text-shadow: .55rem .55rem $colour;
}

Ce qui nous permet ici d'appliquer les ombres de la couleur que l'on veut.

On peut régler la valeur par défaut qui sera utilisé en écrivant :

@mixin heading-shadow($colour: $colour-primary){
  text-shadow: .55rem .55rem $colour;
}

Si aucune couleur n'est spécifiée alors l'ombre sera de la couleur principale (colour-primary).

Écrire du code plus propre grâce aux extensions Sass

Attention en utilisant trop de mixins cela créer une duplication de l'ensemble de règles dans le CSS compilé. Il comporte de multiples répétitions.

Heureusement, les extensions existent. Pour cela on utilise un placeholder, càd un bloc de code qui va être réutilisé dans les à l'aide de @extend pour les sélecteurs voulus.

%typography {
  color: $colour-primary;
  font-size: 2rem;
  font-weight: 100;
  line-height: 1.7;
}
h1 {
@extend %typography;
}
textarea {
  @extend %typography;
}
button {
  @extend %typography;
}
input {
  @extend %typography;
}

Ainsi lorsque l'on regarde le CSS compilé, il n'y a plus de répétitions mais une liste des sélecteurs concernés :

h1, textarea, button, input {
color: #15dea5;
font-size: 2rem;
font-weight: 100;
line-height: 1.7;
}

Mixins Vs Extensions

Bien que les extensions évitent les répétions, il est préférable d'utiliser les mixins. En effet, les extensions démolissent l'ordre et la prédictibilité du codebase. De plus, les extensions n'acceptent pas d'arguments contrairement aux mixins.

Conditions dans Sass

Il est possible d'instaurer des conditions dans Sass. Cela s'écrit :

@if ( lightness($colour) < 25% ) {
  $colour: lighten($colour, 10%);
}@else{
  $colour: darken($colour, 10%);
}

On peut donc créer des mixins modulables en fonctions de certains paramètres ;

@mixin heading-shadow($colour: $colour-primary, $size: $heading-shadow-size){
  @if ( lightness($colour) < 25% ) {
      $colour: lighten($colour, 10%);
  }@else{
      $colour: darken($colour, 10%);
  }
  text-shadow: $size $size $colour;
}

Créer des fonctions

Il est possible de créer des fonctions avec le @function Nom_de_la_fonction(Arguments). Pour récupérer une valeur on utilise @return. Voici un exemple de fonction qui modifie la couleur :

@function lightness-shift($colour){
  @if ( lightness($colour) < 25% ) {
      @return lighten($colour, 10%);
  }@else{
      @return darken($colour, 10%);
  }
}

Je n'ai pas eu le temps de finir toute la formation openclassrooms, il me reste encore la dernière partie : "Optimisez votre code en utilisant les techniques avancées de Sass"