Week 5
DAG studenten: Pushen naar Github VOOR vrijdag 12/3/2021 23:59 AVOND studenten: Pushen naar Github VOOR zondag 14/3/2021 23:59
Setup
Maak een folder Labo4
in de folder die we vorige week hebben aangemaakt. Maak daar een bestand aan dat noemt oefening1.ts
en commit/push die file, en kijk na of je die ook op Github ziet staan!
Belangrijk: Na elk stukje code dat je schrijft, test je jouw code. Wanneer die werkt, commit je die code! Zo kan je altijd terugkeren naar een werkende versie, en kunnen wij ook jouw vooruitgang volgen.
Belangrijk: We werken met TypeScript. Type dus ook alle variabelen en functies
Modules
We gaan nog eventjes opnieuw een module inladen. Om ons require
probleem op te lossen, kunnen we gebruik maken van hetvolgende in de terminal (in jouw Labo4 folder):
Als npx tsc niet werkt, kan je ook tsc --init
doen
Dit initialiseert jouw project voor TypeScript en maakt een bestand genaamd tsconfig.json
. Kijk gerust eens rond in dit bestand. Dit laat ons ook toe require
te gebruiken zoals de meeste npm packages voorstellen. Dit doen we door de lijn "moduleResolution": "node",
te activeren. Verwijder de //
die zorgen dat dit uitgecomment is. Om te testen of alles werkt, maak oefening 1!
Oefening 1: Cat-me
Deze oefening maak je in bestand oefening1.ts
.
Niet alle oefeningen moeten moeilijk zijn ;) We gaan gebruik maken van de module cat-me. Volg de instructies op de npm pagina en print een kat op jouw console. Zorg dat je zeker require
gebruikt!
Oefening 2a: Interfaces
Deze oefening maak je in bestand oefening2.ts
.
Hieronder zie je een json object:
In jouw ts file, maak een variable thematrix
van het Interface type Movie
en zorg dat die variable de properties en waarden van hierboven bevatten.
De interface Movie maak je natuurlijk zelf
Vergeet niet dat er een verschil in notatie is tussen JSON en een object in TypeScript
Maak een tweede variable aan myfavoritemovie
van het type Movie en geef die een object mee die de info over jouw favoriete film bevat.
Maak een derde variable aan myworstmovie
van het type Movie en geef die een object mee die de info over jouw meest gehate film bevat.
Oefening 2b: Functions
Deze oefening maak je in OOK in bestand oefening2.ts
.
In deze oefening maken we 2 functies aan:
de functie
wasMovieMadeInThe90s
met de parameter
movie
van typeMovie
met return waarde
true
orfalse
(of de film in de jaren 90 is gemaakt of niet)roep deze functie op met The Matrix en jouw favoriete film
de functie
averageMetaScore
met de parameter
movies
die een array van het typeMovie
bevatmet return waarde de gemiddelde score van alle films in die array
print het gemiddelde van metascore van de 3 films adhv deze functie
de functie
fakeMetaScore
met de parameters
movie
van het typeMovie
newscore
die een nieuwe score bevat
met return waarde een nieuw
Movie
object met de nieuwe score
Oefening 2c: Functions
Deze oefening maak je in OOK in bestand oefening2.ts
.
Maak 3 interfaces aan:
een interface die de functie
wasMovieMadeInThe90s
omschrijfteen interface die de functie
averageMetaScore
omschrijfteen interface die de functie
fakeMetaScore
omschrijft
Commit/push!
Zorg dat je al jouw commits pusht naar Github voor vrijdag 23:59 (DAGstudenten) of zondag 23:59 (AVONDstudenten)
Last updated