Flex
Plassering av elementer
Hittil har vi sett litt hvordan man kan endre stil på elementene vi ønsker, og vi har jobbet med egenskapene til boks-modellen. Ettersom man har hatt et ønske om å ha bedre kontroll over hvordan elementer skal plasseres, er det utviklet flere mer avanserte teknikker som vi nå skal se nærmere på. Den første av disse kalles flex. Vi bruker gjerne flex når vi skal posisjonere elementer i én dimensjon, altså på en linje eller en rad.
Posisjonering av lenker med flex
Som vanlig er det best å starte med et eksempel. De aller fleste nettsteder du besøker består av mange undersider, og har da en felles fane der du lett kan navigere deg rundt. La oss bruke flex til å lage en slik fane med lenker på toppen av nettsidene våre. Det er naturlig å skrive denne koden i et header
-element, før resten av innholdet som vi legger i main
-elementet:
<body>
<header>
<nav>
<a href="...">Lenke 1</a>
<a href="...">Lenke 2</a>
<a href="...">Lenke 3</a>
<a href="...">Lenke 4</a>
<a href="...">Lenke 5</a>
</nav>
</header>
<main>
(...)
</main>
</body>
Uten CSS ser det ikke spesielt imponerende ut:
Vi skal nå vise hvordan vi ganske enkelt kan posisjonere lenkene slik vi ønsker ved hjelp av flex i CSS. Da trenger vi alltid et element som forelder for det vi skal posisjonere. Vi ser av koden i eksempelet over, at nav
-elementet passer fint som en slik forelder.
Vi starter med å skru på flex på forelder-elementet.
nav{
display: flex;
}
Legg merke til at ingenting endrer seg enda, vi har bare satt igang verktøyet og må nå vite hvilke muligheter vi har tilgjengelig.
Flex - egenskaper
Når flex er "skrudd på" får vi en del nye egenskaper å forholde oss til:
flex-direction
: row / column. Her bestemmer vi om fleks-elementene skal plasseres langs en rad eller kolonne. Standardinnstillingen errow
altså horisontalt, og vi trenger derfor ikke denne egenskapen med mindre lenkene våre skal ligge vertikalt.justify-content:
flex-start / flex-end / center / space-between /space-around. Den viktigste egenskapen for posisjonering. Vi ser nærmere på denne i eksempler nedenfor.align-items:
flex-start / flex-end / center / baseline. Her bestemmer vi hvordan elementene skal legge seg i "motsatt retning" av det vi valgte i "flex-direction". Dersom vi har lagt elementene på en rad, vil align-items justere de i høyden. Motsatt vil elementer i en kolonne kunne justeres horisontalt.
Eksempler
I eksemplene som kommer er det flere regelsett for CSS, og noen av egenskapene er kanskje nye for deg. Det er veldig lurt å prøve å lage de samme fanene selv, og eksperimentere med verdiene. Hva skjer når du endrer på ting, eller fjerner egenskaper. Ved å utforske koden på denne måten, vil du lære veldig mye om hvordan CSS og flex fungerer!
Alternativ 1 - Horisontal Spredning
La oss pynte på navigasjonsfanen vår, se nøye på hver egenskap og resultatet og prøv å avgjøre hva hver linje gjør.
nav{
background-color: lightgrey;
padding-top: 20px;
padding-bottom: 20px;
border-bottom: solid black 2px;
display: flex;
justify-content: space-between;
align-items: center;
}
nav a{
color: black;
text-decoration: none;
}
Resultatet blir:
Vi ser at "space-around" gjør at barna til nav fyller hele skjermen, men like mye luft på hver side.
text-decoration: none;
er en egenskap som fjerner understreken på lenkene.
Alternativ 2 - Horisontalt Venstrestilt
En annen variant er å legge padding på selve lenkene, og bruke "flex-start" i stedet. Flex-start legger alle elementene ved begynnelsen, og padding sørger for at det er luft i mellom:
nav{
padding-top: 20px;
padding-bottom: 20px;
border-bottom: solid black 2px;
display: flex;
justify-content: flex-start;
align-items: center;
}
nav a{
text-decoration: none;
color: black;
padding-right: 30px;
}
Resultat:
Alternativ 3 - Mobil/Vertikal
For en nettside til mobiltelefon, er som oftest det beste å ha fleks-elementene i en kolonne. Vi endrer flex-direction så lenkene kommer under hverandre. Vi bruker - som i forrige eksempel - padding for luft mellom lenkene, og til slutt så sentrerer vi lenkene horisontalt ved hjelp av align-items:
nav{
background-color: lightgray;
padding-top: 20px;
padding-bottom: 20px;
border-bottom: solid black 2px;
border-top: solid black 2px;
display: flex;
flex-direction: column;
align-items: center;
}
nav a{
text-decoration: none;
color: black;
padding-bottom: 10px;
}
Resultat:
Alternativ 4 - Horisontalt i grupper
Ofte er det vanlig å ha lenker til nettstedet til venstre, og innlogging eller min side til høyre. Vi nøster lenkene slik at det bare blir to fleks-barn og legger space-between
på disse:
<body>
<header>
<nav class="flex-container">
<div id="venstre-lenker">
<a href="...">Lenke 1</a>
<a href="...">Lenke 2</a>
<a href="...">Lenke 3</a>
<a href="...">Lenke 4</a>
</div>
<div id="høyre-lenker">
<a href="...">Lenke 5</a>
<a href="...">Lenke 6</a>
</div>
</nav>
</header>
</body>
nav{
background-color: lightgray;
padding-top: 20px;
padding-bottom: 20px;
border-bottom: solid black 2px;
display: flex;
justify-content: space-between;
align-items: center;
}
nav a{
color: black;
text-decoration: none;
padding-right: 30px;
}
Resultat:
I eksemplene ovenfor har vi brukt padding for luft mellom elementene.
Alternativt kan man bestemme størrelsen til et fleks-element ved å bruke egenskapen flex-basis
. Les mer om denne her.
Oppgaver
3.4.1
Ta for deg nettavisen du jobbet med i 2.5.2 og 3.2.1. Fjern eventuell marg mellom lenkene og bruk flex samt annen CSS til å få navigasjonsfanen til å se omtrent slik ut:
3.4.2
Bruk Flex og gjenskap TV2 Plays pakkevelger.
- Tips: fonten
Helvetica
er ganske lik TV2 Plays sin.
3.4.3
Gjenskap Spotifys nettside.
- Tips: fonten
Montserrat
er ganske lik Spotifys, du finner den på Google Fonts: Montserrat.