Aller au contenu

API REST à la recherche d’un front dynamique en JS

starwars

Le but de ce projet est de montrer comment consommer une API REST dans une page web.

Pour taper dans (l’oeil de) l’api (qui est composée d’url), vous pouvez utiliser différentes techniques :

Au chargement de la page, il faudra récupérer la liste complète des personnages de starwars en utilisant le endpoint : https://swapi.dev/api/people.

On utilisera cette liste pour remplir le dropdown (liste déroulante).

On veut aussi que la sélection d’un personnage dans cette liste déroulante donne du détail dans un élément card.

Voici un exemple du résultat attendu (en très moche !):

img

Squelette html

Remarque : Si vous choisissez Jquery, prenez une seule version de jquery (car bootstrap propose aussi d’en utiliser une), et la version slim ne convient pas, il faut la minified. Pour les autres choix, ras.

Version JQuery (old technique, voire obsolète mais ça fonctionne toujours !))

Il faudra dans ce cas charger JQuery.

// contient la liste de tous les people reçue par l'api starwars
var liste = [];

/**
 * Action à réaliser lorsque le dom est chargé
 */
$(document).ready(function () {
    // on utilise jquery pour faire appel à l'api de starwars
    $.ajax({
        url: "https://swapi.co/api/people"
    }).then(function (data) {
        liste = data['results'];
        chargerMenu();
    });
});

/**
 * remplit le dropdown menu avec les noms de tous les people de la liste
 */
function chargerMenu() {
  liste.forEach(function (item) {
    // affichage dans la console pour vérifier uniquement
    // à compléter
    console.log(item);
  });
}
<body>
...
<script src="main.js"></script>
</body>

A Faire

Pour cette partie, travaillez en pair programming avec quelqu’un qui a un peu d’expérience en js :

let newMenuItem = document.createElement('button');
newMenuItem.className = "dropdown-item";
newMenuItem.type = "button";
...
document.getElementById("dropdown-list").appendChild(newMenuItem);

Déploiement/hébergement par netlify/github ou autre.

Pour déployer le projet (rendre accéssible sur le web), une solution simple est de créer un projet sous github (hébergement) et de le connecter à un compte netlify.

Version améliorée

Conseil : Utiliser uniquement la méthode fetch() de Javascript.

Fonctionnalités

Un titre différent pour chaque page serait bien.

Il faut bien lire la documentation de l’api SWAPI

Idéal : Travail à réaliser par deux

Bon courage !