L'évolution de la construction des interfaces Web 🚀

Ecrit le 24/11/2023

Dans le développement des interfaces Web, nous avons vu une évolution significative dans la façon dont nous construisons nos applications. Partons du début, où nous utilisions principalement HTML, CSS et JavaScript pour coder nos interfaces, jusqu’à aujourd’hui où nous avons des approches plus avancées et flexibles.

Étape 1: Construction manuelle avec HTML, CSS et JS

Au tout début, nous devions coder manuellement chaque aspect de notre interface en utilisant HTML, CSS et JavaScript. Cela impliquait de répéter beaucoup de code pour des éléments similaires et rendait la maintenance et la personnalisation de l’interface assez fastidieuses. Chaque changement nécessitait une modification manuelle du code.

Exemple de composant de pagination en HTML, CSS et JS :

<div class="pagination-container">
  <button class="pagination-item">1</button>
  <button class="pagination-item">2</button>
  <button class="pagination-item">3</button>
  <!-- ... -->
</div>

<style>
  .pagination-container {
    /* styles pour le container */
  }

  .pagination-item {
    /* styles pour chaque bouton de pagination */
  }
</style>

<script>
  // Logique pour la pagination
</script>

Étape 2: Utilisation de composants React et des bibliothèques comme Bootstrap et DaisiUI

Avec l’introduction de React et des bibliothèques de composants comme Bootstrap et DaisiUI, nous avons pu commencer à utiliser des composants préconstruits pour construire nos interfaces. Cela nous a permis de gagner du temps et de l’effort en utilisant des composants prêts à l’emploi avec des fonctionnalités et des styles prédéfinis. Cependant, nous avons souvent rencontré des difficultés pour personnaliser pleinement le design selon nos besoins spécifiques.

Exemple de composant de pagination avec des composants React et la bibliothèque Bootstrap :

import React from 'react';
import { Pagination } from 'react-bootstrap';

function PaginationComponent() {
  return (
    <Pagination>
      <Pagination.Item>1</Pagination.Item>
      <Pagination.Item>2</Pagination.Item>
      <Pagination.Item>3</Pagination.Item>
      {/* ... */}
    </Pagination>
  );
}

export default PaginationComponent;

Étape 3: Utilisation de Tailwind CSS

Tailwind CSS est une autre approche populaire dans la construction des interfaces Web. Elle offre une grande liberté dans le design en utilisant des classes utilitaires pour styliser les éléments. Cela nous permet de personnaliser facilement notre interface en utilisant des classes prédéfinies pour les marges, les couleurs, les polices, etc. Cependant, nous perdons souvent une partie de la logique et de la structure de notre interface en utilisant uniquement Tailwind CSS.

Exemple de composant de pagination avec Tailwind CSS :

import React from 'react';

function PaginationComponent() {
  return (
    <div className="pagination-container">
      <button className="pagination-item">1</button>
      <button className="pagination-item">2</button>
      <button className="pagination-item">3</button>
      {/* ... */}
    </div>
  );
}

export default PaginationComponent;

Étape 4: Utilisation des composants Headless

Plus récemment, une approche émergente consiste à utiliser des composants Headless pour la construction des interfaces Web. Cette approche combine la liberté de conception offerte par des outils comme Tailwind CSS avec la possibilité de conserver la logique de l’interface. Les composants Headless sont des composants qui ne sont pas liés à un design spécifique, mais plutôt axés sur la logique et la fonctionnalité. Nous pouvons utiliser des bibliothèques comme React pour construire ces composants Headless et utiliser Tailwind CSS pour styliser l’interface selon nos besoins.

Exemple de composant de pagination Headless avec React Headless Component :

import React from 'react';
import { Pagination } from 'react-headless-component';
import 'tailwindcss/tailwind.css';

function PaginationComponent({ totalItems, itemsPerPage }) {
  const totalPages = Math.ceil(totalItems / itemsPerPage);

  const handlePageChange = (page) => {
    // Logique pour changer de page
  };

  return (
    <Pagination
      totalPages={totalPages}
      onPageChange={handlePageChange}
      activePage={1}
      showPrevNextButtons
      showFirstLastButtons
      className="pagination-container"
      itemClassName="pagination-item"
      activeItemClassName="active"
    />
  );
}

export default PaginationComponent;

Dans cet exemple, nous utilisons le composant Pagination de la librairie react-headless-component pour gérer la logique de pagination. Nous passons les props nécessaires, tels que totalPages, onPageChange, activePage, showPrevNextButtons, showFirstLastButtons, className, itemClassName et activeItemClassName. Nous utilisons également Tailwind CSS pour styliser notre interface de pagination en utilisant des classes utilitaires.

Conclusion

L’évolution de la construction des interfaces Web nous a permis de passer de la construction manuelle fastidieuse à des approches plus flexibles et efficaces. Des outils comme React, Bootstrap, Tailwind CSS et les composants Headless nous offrent une meilleure gestion de l’interface et de la logique.

En utilisant les composants Headless, nous pouvons profiter de la liberté de design offerte par Tailwind CSS tout en conservant la logique et la structure de notre interface. Essayez d’explorer ces différentes approches dans votre prochain projet et découvrez celle qui convient le mieux à vos besoins ! 💥✨