Een oefening in Layout Modes met CSS. Fork deze deeltaak, en ga aan de slag.
Deze leertaak hoort bij Sprint 2 The Client. Dit is een deeltaak die je individueel uitvoert en waarmee je bewijslast verzamelt.
In het college S02W02 Flow en Layout wordt verteld over Layout Modes in CSS. Deze deeltaak behandelt verschillende typen layouts en is bedoeld als robuuste oefening in het maken van layouts.
CSS heeft een aantal verschillende manieren waarop je HTML kunt voorzien van een layout. Elke manier heeft eigen voor- en nadelen, en het is goed om de verschillende methodes je eigen te maken. Layout modes zijn ook te combineren, waardoor je verschillende ontwerpproblemen kunt oplossen.
Nadat je gestructureerde HTML hebt gemaakt, kun je elk onderdeel van een pagina of component van layout voorzien. En gecombineerd met media queries kun je responsive layouts maken.
In onderstaande afbeelding zie je 18 verschillende layouts die je met CSS kunt maken. Negen daarvan zijn basic layouts welke je met Normal Flow, Grid Layout, Flexible Box Layout, Float Layout en Positioned Layout kunt maken. Naast deze basic layouts zijn er ook negen advanced layouts waarvoor je iets meer trucage uit je mouw moet schudden.
Waarom zou je dit doen? Omdat je oefent met veel verschillende layouts en verschillende Layout Modes. Na het succesvol implementeren van alle bovenstaande layouts heb je altijd een soort spiekbriefje om naar terug te kijken als je een layout maakt.
“Wax on right hand. Wax off left hand. Wax on, wax off. Breathe in through nose, out through mouth. Wax on, wax off. Don't forget to breathe. Very important.” - Mr. Miyagi
Omdat deze deeltaak bestaat uit 18 kleine opdrachten doorloop je telkens de development lifecycle. Misschien had je al vaker het idee dat je dit telkens in het klein doet bij elke grotere opdracht, als je een probleem oplost.
Werk in eerste instantie alle 9 basic layouts uit, en ga door met de advanced layouts als je nog zin hebt in een uitdaging. Voor elke layout die je uit gaat werken, gelden onderstaande stappen, die je dus meerdere keren doorloopt.
Kies een layout die je gaat maken. Onderzoek kort welke Layout Mode hiervoor geschikt is. Hieronder staat een lijst met hints die je zou kunnen gebruiken.
- Maak een nieuw issue aan op jouw geforkte repo, met daarin de naam en het nummer van de layout die je gaat maken.
- Schrijf alvast wat hints over de Layout Mode die je gaat gebruiken, en links naar bronnen die je nodig gaat hebben in de beschrijving van je issue.
- Ga door naar de stappen bij “Ontwerpen” hieronder.
- Basic layout 1: Grid Layout
- Basic layout 2: Flow Layout, Grid Layout of Flexible Box Layout
- Basic layout 3: Grid Layout
- Basic layout 4: Grid Layout
- Basic layout 5: Flow Layout, Grid Layout of Flexible Box Layout
- Basic layout 6: Grid Layout
- Basic layout 7: Flow Layout én Float Layout gecombineerd
- Basic layout 8: Flow Layout én Positioned Layout gecombineerd
- Basic layout 9: Grid Layout én Flexible Box Layout gecombineerd
Voor de advanced layouts kun je deze hints gebruiken:
- Advanced layout 1: Multi-column Layout of Masonry Layout (experimenteel)
- Advanced layout 2: Grid Layout + rotate transforms
- Advanced layout 3: Grid Layout
- Advanced layout 4: Grid Layout + skew transforms of clip-path
- Advanced layout 5: Grid Layout
- Advanced layout 6: Grid Layout of Positioned Layout
- Advanced layout 7: Grid Layout of Positioned Layout + rotate transforms
- Advanced layout 8: Positioned Layout + rotate transforms
- Advanced layout 9: Grid Layout + border-radius of clip-path
- Layout mode @ MDN
- Layout @ web.dev
- CSS layout @ MDN
- A Complete Guide to Grid @ CSS Tricks
- A Complete Guide to Flexbox @ CSS Tricks
- Flow Layout @ MDN
- Floats @ MDN
- CSS challenge 1: Grid, door Sanne
- CSS challenge 4: Flexbox, door Sanne
Maak een snelle breakdown schets van de CSS, welke je gebruikt om de layout te implementeren.
- Onderzoek met behulp van bovenstaande bronnen en hints hoe je de layout zou kunnen maken in CSS, en welke eigenschappen van die Layout Mode je hiervoor nodig gaat hebben.
- Teken de layout na op papier en zet er wat annotaties bij over hoe je de vlakverdeling met CSS kunt bereiken.
- Voor Grid Layout: teken de grid lines met een afwijkende kleur over de layout heen.
- Voeg je schets toe als reactie op het issue dat je net hebt aangemaakt.
- Ga door naar de stappen bij “Bouwen”.
Implementeer de layout in het betreffende HTML bestand dat al voor je klaar staat.
- Gebruik de hints, de bronnen hierboven, je eigen onderzoek en je breakdown schets om de CSS voor de layout uit te schrijven in het HTML bestand dat al voor je klaar staat in de
basic
enadvanced
mappen in deze repo. Als het goed is, hoef je aan de HTML zelf niets te veranderen, en kun je in het<style></style>
element aan de slag. - Gebruik voor Grid Layout en Flexible Box Layout de inspector tools in je devtools. Zie de bronnen hieronder voor meer informatie.
- Vraag regelmatig om feedback of hulp, en overleg met medestudenten.
- Check doorlopend jouw aanpassingen in de browser (baby-steps approach), totdat je tevreden bent. De layouts hoeven uiteraard niet pixel-perfect nagemaak te worden.
- Ga door naar de stappen bij “Integreren”.
- CSS Grid Inspector: Examine grid layouts @ Firefox
- CSS Flexbox Inspector: Examine Flexbox layouts @ Firefox
- Inspect CSS grid layouts @ Chrome
- Inspect and debug CSS flexbox layouts @ Chrome
Voer een commit uit op jouw GitHub repository met de layout die je zojuist geïmplementeerd hebt. Op deze manier kan je altijd terug naar een versie waarvan je weet dat alles in orde was.
- Voer in GitHub een commit message in, gebruik de naam van de layout die je zojuist geïmplementeerd hebt, en noem het nummer van het issue waar je aan werkt.
- Push je code naar GitHub.
- Ga door naar de stappen bij “Testen”.
Test in een browser of de versie die je net online gezet hebt ook via GitHub Pages werkt.
- Open jouw repository via de directe link van GitHub Pages.
- Check of alles werkt.
- Vergelijk jouw implementatie even met een klasgenoot.
- Als je iets nieuws hebt gebruikt voor deze layout, beschrijf dit dan in je Learning Journal.
Ga hierna opnieuw door al deze stappen heen met een volgende layout.
Deze opdracht is done als:
- De 9 basis layouts zijn voltooid aan de hand van bovenstaande stappen.
- Alle breakdown schetsen voor de layouts in je issues zijn opgenomen.
- Al je werk is te bekijken via GitHub pages.