Le projet de cette semaine est la mise en pratique de l'introduction au Framework React.js pour développer des applications complexes. Pour le bien de cette mise en pratique nous requêterons l'API star Wars SWAPI qui propose une liste ordonnée et complexe d'informations sur la saga star Wars. Notre but sera de créer une application Web capable de naviguer et rechercher parmi les informations fournies dans l'API en proposant une interface agréable et fonctionnelle.
Pour réaliser ce projet, j'utilise :
- Node.js
- react.js
- react router dom
- Bootstrap
- Git-GiHub
- création du dossier de travail via la console PowerShell, installation de Node.js, installation du dossier projet avec React.js, installation de react router dom, nettoyage des fichiers inutiles et appropriation de la base de dossiers, création du README.md.
- création du README.md dans le dossier src expliquant l'architecture de mon arborescence "composents".
- Étude du cahier des charges et élaboration des documents d'organisation du projet sur GitHub.
- Header - nav - footer faits, accueil statique pratiquement fini.
- Accueil fini en mode static, restera la hauteur de la page à fixer.
- Accueil static terminée, page parcourir statique terminée, http request axios intégré.
- API connectée sur la page Accueil, reste à savoir quoi faire avec les liens des catégories.
Dossier d'architecture des fichiers du site, ici j'organise mes dossiers et fichiers pour une bonne pratique de React, le but étant de prendre dès le début une attitude de projets complexes.
- components - est le dossier parent de tous mes éléments DOM éclatés en parents enfants suivant l'arborescence.
- layout - dossier contenant mes éléments communs à toutes mes pages, header, nav et footer.
- layout>header - dossier contenant les éléments du header.
- layout>nav - dossier contenant l'élément du nav.
- layout>footer - dossier contenant l'élément du footer.
- home - dossier contenant les éléments de la page d'accueil.
- search - dossier contenant les éléments de la page parcourir.
- search>serachezone - dossier contenant l'élément input de saisie de l'utilisateur.
- search>listzone - dossier contenant l'élément affichant la liste renvoyée lors de la saisie de l'utilisateur.