React 2 (React Movie Explorer - concept 13/1)
Vite + React
Projectnaam: "React Movie Explorer"
Beschrijving: Studenten bouwen een interactieve webapplicatie waarmee gebruikers informatie over films kunnen opzoeken. De applicatie gebruikt een externe API, zoals de OMDb API of een andere gratis films-API. Gebruikers kunnen zoeken naar films, details bekijken (zoals titel, genre, plot, en poster), en een lijst van favoriete films bijhouden.
Functionaliteiten:
-
Zoekfunctionaliteit:
- Gebruiker kan een film zoeken op naam.
- Zoekresultaten worden dynamisch weergegeven.
-
Film Details:
- Klik op een film in de lijst om meer details te bekijken (bijvoorbeeld een aparte pagina of een popup).
-
Favorieten:
- Gebruikers kunnen films toevoegen aan een lijst met favorieten.
- Favorieten worden opgeslagen in de
localStorage
, zodat ze blijven bestaan na het herladen van de pagina.
-
Responsief Design:
- De app werkt goed op zowel desktop als mobiel.
-
Vite + React:
- Vite zorgt voor een snelle ontwikkelomgeving.
- Studenten leren component-gebaseerde ontwikkeling met React, inclusief statebeheer met
useState
enuseEffect
.
Extra Opties voor Gevorderde Studenten:
- Filteren op genre of jaar: Voeg extra filters toe.
- Paginering: Zorg dat zoekresultaten verdeeld worden over meerdere pagina's.
- Themawisselaar: Laat gebruikers wisselen tussen een licht en donker thema.
Benodigde tools en kennis:
-
Tools:
- Vite: Voor snelle projectopzet.
- React: Voor het bouwen van componenten.
- API zoals OMDb API (registreer voor een gratis API-sleutel).
- CSS-framework (optioneel): Tailwind, Bootstrap, of handgemaakte CSS.
-
Kennis:
- Basis JavaScript en ES6+ (bijv.
fetch
API). - React-beginselen (
useState
,useEffect
, props, componenten). - Basis HTML/CSS.
- Basis JavaScript en ES6+ (bijv.
Projectopbouw:
-
Les 1: Introductie en opzet
- Installeer Node.js, Vite, en maak een nieuw project.
- Begrijp de folderstructuur van Vite + React.
- Bouw een eenvoudige React-component die een "Hello World" bericht toont.
-
Les 2: API-integratie
- Leer hoe je de OMDb API gebruikt met
fetch
. - Bouw een zoekbalk en toon resultaten.
- Leer hoe je de OMDb API gebruikt met
-
Les 3: Statebeheer en favorieten
- Gebruik
useState
voor statebeheer. - Voeg een favorietenfunctie toe en sla favorieten op in
localStorage
.
- Gebruik
-
Les 4: Styling en afronding
- Voeg styling toe met CSS of een framework.
- Maak de app responsive.
- Voeg een themawisselaar toe als bonus.
Les 1: Introductie en opzet
Doel van de les
In deze les leren studenten hoe ze een Vite + React-project opzetten, de folderstructuur begrijpen en een eenvoudige React-component bouwen die een "Hello World" bericht toont.
Stap 1: Installeren van Node.js
-
Controleer of Node.js is geïnstalleerd:
- Open een terminal (Command Prompt, PowerShell of een andere terminal).
- Typ het volgende commando:
node -v
- Als er een versie wordt weergegeven (bijvoorbeeld
v18.16.0
), dan is Node.js al geïnstalleerd.
-
Installeer Node.js als dit nog niet is gebeurd:
- Ga naar de officiële Node.js-website.
- Download de LTS-versie (Long Term Support).
- Volg de installatie-instructies.
-
Controleer ook npm (Node Package Manager):
- Typ in de terminal:
npm -v
- Dit toont de versie van npm. Het wordt automatisch met Node.js geïnstalleerd.
- Typ in de terminal:
Stap 2: Een Vite + React-project opzetten
-
Maak een nieuw project aan met Vite:
- Typ in de terminal:
npm create vite@latest my-react-app
- Kies de volgende opties:
- Projectnaam:
my-react-app
(of een andere naam naar keuze). - Framework:
React
. - Variant:
JavaScript
(voor beginners).
- Projectnaam:
- Typ in de terminal:
-
Navigeer naar de projectmap:
cd my-react-app
-
Installeer de benodigde afhankelijkheden:
npm install
-
Start de ontwikkelserver:
npm run dev
- Noteer het adres (meestal
http://localhost:5173
) dat in de terminal wordt weergegeven. - Open dit adres in een webbrowser. Je zou een standaard Vite-react-startpagina moeten zien.
- Noteer het adres (meestal
Stap 3: Begrijp de folderstructuur
In de projectmap zie je de volgende belangrijke mappen en bestanden:
src/
main.jsx
: Het startpunt van de applicatie. Hier wordt React geïntegreerd met de browser.App.jsx
: De hoofdcomponent van de applicatie.
index.html
: De HTML-pagina waarin de React-app wordt geladen.vite.config.js
: Configuratiebestand voor Vite.
Leg uit dat src/
de map is waar alle React-code zich bevindt.
Stap 4: Bouw een eenvoudige React-component
- Open de
App.jsx
in een code-editor (bijv. VS Code). - Pas de inhoud aan om een eenvoudige "Hello World"-component te maken:
function App() { return ( <div> <h1>Hello World</h1> <p>Welkom bij je eerste React-app!</p> </div> ); } export default App;
- Opslaan en bekijken:
- Sla het bestand op.
- Ga terug naar de browser en vernieuw de pagina. Je zou nu de tekst "Hello World" en "Welkom bij je eerste React-app!" moeten zien.
Extra uitdaging (optioneel)
- Voeg je eigen tekst of een afbeelding toe aan de component.
- Experimenteer met HTML-tags zoals
<button>
en<input>
.
Samenvatting van de les
- Studenten hebben geleerd hoe ze Node.js, Vite en React instellen.
- Ze begrijpen de basis van de Vite + React-folderstructuur.
- Ze hebben een eenvoudige "Hello World" React-component gebouwd.
Voorbereiding voor les 2
- Zorg dat je
npm run dev
kunt uitvoeren en de app werkt in de browser. - Lees alvast over de
useState
-hook in React (optioneel).
Les 2: API-integratie
Doel van de les
Studenten leren hoe ze de OMDb API kunnen gebruiken met de fetch
-methode in JavaScript en bouwen een eenvoudige zoekfunctionaliteit om filmresultaten weer te geven in hun React-app.
Stap 1: De OMDb API begrijpen
-
Wat is de OMDb API?
- Een gratis API waarmee je informatie over films kunt ophalen, zoals titel, jaar, genre, en een poster.
- API-documentatie: OMDb API.
-
Vraag een API-sleutel aan:
- Ga naar de website van OMDb en registreer je voor een gratis API-sleutel.
- Noteer deze sleutel, want deze is nodig om de API te gebruiken.
Stap 2: Een zoekfunctionaliteit toevoegen
-
Bewerk de
App.jsx
:- Open het bestand
App.jsx
. - Vervang de bestaande code door onderstaande basisopzet:
import { useState } from 'react'; function App() { const [searchTerm, setSearchTerm] = useState(''); const [movies, setMovies] = useState([]); const API_KEY = 'JOUW_API_SLEUTEL_HIER'; const searchMovies = async () => { const response = await fetch(`https://www.omdbapi.com/?apikey=${API_KEY}&s=${searchTerm}`); const data = await response.json(); if (data.Search) { setMovies(data.Search); } else { setMovies([]); } }; return ( <div> <h1>React Movie Explorer</h1> <div> <input type="text" placeholder="Zoek een film..." value={searchTerm} onChange={(e) => setSearchTerm(e.target.value)} /> <button onClick={searchMovies}>Zoeken</button> </div> <div> {movies.length > 0 ? ( <ul> {movies.map((movie) => ( <li key={movie.imdbID}> <h2>{movie.Title}</h2> <p>{movie.Year}</p> <img src={movie.Poster} alt={movie.Title} /> </li> ))} </ul> ) : ( <p>Geen films gevonden. Probeer een andere zoekterm.</p> )} </div> </div> ); } export default App;
- Open het bestand
-
Uitleg over de code:
- Statebeheer:
searchTerm
: Houdt bij wat de gebruiker intypt in de zoekbalk.movies
: Slaat de zoekresultaten op.
fetch
:- Roept de OMDb API aan met de ingevoerde zoekterm.
- Dynamische rendering:
- De lijst met films wordt weergegeven op basis van de API-resultaten.
- Statebeheer:
Stap 3: Test de zoekfunctionaliteit
- Start de ontwikkelserver:
npm run dev
- Open de app in de browser:
- Typ een zoekterm in (bijvoorbeeld "Avengers") en klik op de knop "Zoeken".
- Controleer of de resultaten worden weergegeven met titel, jaar, en poster.
Stap 4: Styling toevoegen (optioneel)
-
Basis CSS toevoegen:
- Maak een nieuw bestand
App.css
in desrc/
map:body { font-family: Arial, sans-serif; margin: 0; padding: 0; text-align: center; } input { padding: 8px; margin: 10px; width: 200px; } button { padding: 8px 12px; background-color: #007BFF; color: white; border: none; cursor: pointer; } button:hover { background-color: #0056b3; } img { max-width: 150px; margin: 10px; } ul { list-style-type: none; padding: 0; } li { display: inline-block; margin: 10px; }
- Maak een nieuw bestand
-
Importeer de CSS in
App.jsx
:import './App.css';
-
Bekijk het resultaat:
- Herlaad de pagina om te zien hoe de app er nu uitziet met styling.
Samenvatting van de les
- Studenten hebben geleerd hoe ze de OMDb API kunnen gebruiken met
fetch
. - Ze hebben een zoekbalk gemaakt en filmresultaten weergegeven.
- Optioneel: Styling is toegevoegd om de app visueel aantrekkelijk te maken.
Voorbereiding voor les 3
- Lees over het gebruik van
localStorage
. - Bedenk hoe je een favorietenlijst kunt maken waarin gebruikers films kunnen opslaan.
Les 3: Statebeheer en favorieten
Doel van de les
Studenten leren hoe ze statebeheer met useState
toepassen in React en een favorietenfunctionaliteit implementeren. Favorieten worden opgeslagen in localStorage
, zodat deze behouden blijven na het herladen van de pagina.
Stap 1: Favorieten toevoegen aan state
- Pas de
App.jsx
aan:- Open het bestand
App.jsx
. - Voeg een nieuwe state toe voor het opslaan van favorieten:
import { useState, useEffect } from 'react'; function App() { const [searchTerm, setSearchTerm] = useState(''); const [movies, setMovies] = useState([]); const [favorites, setFavorites] = useState([]); const API_KEY = 'JOUW_API_SLEUTEL_HIER'; const searchMovies = async () => { const response = await fetch(`https://www.omdbapi.com/?apikey=${API_KEY}&s=${searchTerm}`); const data = await response.json(); if (data.Search) { setMovies(data.Search); } else { setMovies([]); } }; const addToFavorites = (movie) => { const updatedFavorites = [...favorites, movie]; setFavorites(updatedFavorites); saveToLocalStorage(updatedFavorites); }; const removeFromFavorites = (movie) => { const updatedFavorites = favorites.filter(fav => fav.imdbID !== movie.imdbID); setFavorites(updatedFavorites); saveToLocalStorage(updatedFavorites); }; const saveToLocalStorage = (items) => { localStorage.setItem('favorites', JSON.stringify(items)); }; const loadFavoritesFromLocalStorage = () => { const storedFavorites = JSON.parse(localStorage.getItem('favorites')) || []; setFavorites(storedFavorites); }; useEffect(() => { loadFavoritesFromLocalStorage(); }, []); return ( <div> <h1>React Movie Explorer</h1> <div> <input type="text" placeholder="Zoek een film..." value={searchTerm} onChange={(e) => setSearchTerm(e.target.value)} /> <button onClick={searchMovies}>Zoeken</button> </div> <div> <h2>Zoekresultaten</h2> {movies.length > 0 ? ( <ul> {movies.map((movie) => ( <li key={movie.imdbID}> <h2>{movie.Title}</h2> <p>{movie.Year}</p> <img src={movie.Poster} alt={movie.Title} /> <button onClick={() => addToFavorites(movie)}>Voeg toe aan favorieten</button> </li> ))} </ul> ) : ( <p>Geen films gevonden. Probeer een andere zoekterm.</p> )} </div> <div> <h2>Favorieten</h2> {favorites.length > 0 ? ( <ul> {favorites.map((favorite) => ( <li key={favorite.imdbID}> <h2>{favorite.Title}</h2> <p>{favorite.Year}</p> <img src={favorite.Poster} alt={favorite.Title} /> <button onClick={() => removeFromFavorites(favorite)}>Verwijder uit favorieten</button> </li> ))} </ul> ) : ( <p>Geen favorieten toegevoegd.</p> )} </div> </div> ); } export default App;
- Open het bestand
Stap 2: Uitleg over de code
-
Statebeheer:
favorites
: Houdt een lijst bij van favoriete films.
-
LocalStorage:
- Functie
saveToLocalStorage
: Slaat de favorieten op in de browser. - Functie
loadFavoritesFromLocalStorage
: Laadt favorieten uitlocalStorage
bij het laden van de app.
- Functie
-
Favorieten toevoegen/verwijderen:
- Toevoegen: De film wordt toegevoegd aan de favorietenlijst en opgeslagen in
localStorage
. - Verwijderen: De film wordt uit de favorietenlijst verwijderd en de wijzigingen worden opgeslagen.
- Toevoegen: De film wordt toegevoegd aan de favorietenlijst en opgeslagen in
-
Gebruik van
useEffect
:useEffect
wordt gebruikt om de opgeslagen favorieten te laden bij het opstarten van de applicatie.
Stap 3: Test de applicatie
- Start de ontwikkelserver:
npm run dev
- Voer een zoekopdracht uit:
- Zoek een film en voeg deze toe aan de favorieten.
- Controleer de favorietenlijst:
- Zie hoe de favorieten verschijnen onder de sectie "Favorieten".
- Herlaad de pagina:
- Controleer of de favorieten behouden blijven dankzij
localStorage
.
- Controleer of de favorieten behouden blijven dankzij
Extra uitdaging (optioneel)
- Voeg een knop toe om alle favorieten in één keer te verwijderen.
- Voeg een melding toe wanneer een film al in de favorieten staat.
Samenvatting van de les
- Studenten hebben geleerd hoe ze statebeheer toepassen met
useState
. - Ze hebben een favorietenfunctionaliteit geïmplementeerd.
- Ze hebben
localStorage
gebruikt om gegevens op te slaan en te laden.
Voorbereiding voor les 4
- Lees over CSS-styling en het verbeteren van gebruikersinterfaces.
- Denk na over hoe je filters of paginering kunt toevoegen aan de zoekresultaten.