# Odin Project HTML and CSS- diary
## Introduction and installing OS and some of the dev tools
##### Command line guide book
http://conqueringthecommandline.com/book/basics
## Git
#### Useful commands
https://www.youtube.com/watch?v=HVsySz-h9r4
Asettaa kansion git- repositoryksi
``` Git
git init
```
Näyttää tämän hetkisen tiedon, tämä on hyvä ajaa heti initin jälkeen
``` Git
git status
```
Luo uuden gitignore tekstitiedoston, jonka avulla voidaan päättää tiedostoja / kansioita, joita ei sisällytetä commitiin / versionhallintaan
``` Git
touch .gitignore
```
Add asettaa tiedostoja ns. staging arealle, joka on välitila työskentelykansion ja versionhallinnan välillä. Reset poistaa tietoja staging arealta
``` Git
git add -a
git reset -a
```
Commit lähettää staging arealta tiedot omaan versionhallintaan
``` Git
git commit -m "Commitin nimi"
```
Clone- komento kloonaa valmiin repositoryn lokaaliin kohteeseen joka annetaan toisena parametrina. Ensimäinnen parametri voi olla lokaali.
``` Git
git clone <URL> <LocalFolder>
```
Näillä komennoilla saadaan tietoja etärepositorysta
``` Git
git remote -v
git branch -a
```
Näillä komennoilla lähetetään tiedot jaettuun versionhallintaan, eli remote repositoryyn. Pull- komento on pakollinen alussa, koska se lataa tuoreimmat tiedot remote reposta ennenkuin sinne lisätään uutta dataa Push-komennolla. Komennossa on parametreina remote repository ja lokaali branch
``` Git
git pull origin master
git push origin master
parametrilla -u voidaan asettaa käytetyt repositoryt defaultiksi, jolloin riittää pelkät
git pull
git push
```
Tällä tarkastellaan missä lokaalissa branchissa työskennellään
``` Git
git branch
```
Tällä luodaan uusi oma lokaali branch
``` Git
git branch <Branchin Nimi>
```
Tällä vaihdetaan toiseen branchiin
``` Git
git checkout <Branchin Nimi>
```
Branchien mergeeminen eli yhdistäminen
``` Git
git checkout <PääBranch>
git pull origin <PääBranch>
git branch --merged
git merge <BranchToMerge>
git push origin <PääBranch>
```
Branchin poistaminen, ensin lokaalisti ja sitten remote reposta
``` Git
git branch --merged
git branch -d <PoistettavaBranch>
git branch -a
git push origin --delete <PoistettavaBranch>
```
-----
## HTML
Suurin osa tekstistä ja koodiesimerkeistä on kopioitu sivuston www.freecodecamp.org koulutuksista.
### Links
#### Internal linking
``` html5
<a href="#contacts-header">Contacts</a>
...
<h2 id="contacts-header">Contacts</h2>
```
To create an internal link, you assign a link's href attribute to a hash symbol # plus the value of the id attribute for the element that you want to internally link to, usually further down the page. You then need to add the same id attribute to the element you are linking to. An id is an attribute that uniquely describes an element.
### Images
``` html5
<img src="https://www.your-image-source.com/your-image.jpg" alt="">
```
Note that img elements are self-closing.
All img elements **must have an alt attribute.** The text inside an alt attribute is used for screen readers to improve accessibility and is displayed if the image fails to load.
Note: If the image is purely decorative, using an empty alt attribute is a best practice.
Ideally the alt attribute should not contain special characters unless needed.
CSS-Sidenote: It is a good practice to set both width and height for the image. This way the space required for the picture is already reserved, even if the image has not yet fully loaded. Height can be left "auto", so the image will keep it's proportions.
### Webforms
Tekstikenttä
``` html5
<input type="text" placeholder="this is placeholder text">
```
Tekstikenttä, joka lähettää kentän tiedot kirjoitettuun URL
``` html5
<form action="/url-where-you-want-to-submit-form-data"><input type="text" placeholder="this is placeholder text"></form>
```
Perusbutton
``` html5
<button type="submit">this button submits the form</button>
```
Note that input elements are self-closing.
For example, if you wanted to make a text input field required, you can just add the attribute required within your input element, like this:
``` html5
<input type="text" required>
```
Radio buttons are a type of input.
Each of your radio buttons can be nested within its own label element. By wrapping an input element inside of a label element it will automatically associate the radio button input with the label element surrounding it.
All related radio buttons should have the same name attribute to create a radio button group. By creating a radio group, selecting any single radio button will automatically deselect the other buttons within the same group ensuring only one answer is provided by the user.
Here's an example of a radio button:
``` html5
<label>
<input type="radio" name="indoor-outdoor">Indoor
</label>
```
It is considered best practice to set a for attribute on the label element, with a value that matches the value of the id attribute of the input element. This allows assistive technologies to create a linked relationship between the label and the child input element. For example:
``` html5
<label for="indoor">
<input id="indoor" type="radio" name="indoor-outdoor">Indoor
</label>
```
Sending data needs Value=" " attribute
```html5
<label for="indoor">
<input id="indoor" value="indoor" type="radio" name="indoor-outdoor">Indoor
</label>
<label for="outdoor">
<input id="outdoor" value="outdoor" type="radio" name="indoor-outdoor">Outdoor
</label>
```
You can set a checkbox or radio button to be checked by default using the ***checked*** attribute.
### Audio
HTML5 tarjoaa mahdollisuuden luoda audio-kontenttia sivustoille. Lisäämällä keyword "controls" audio tagiin, näyttää sivusto peruskontrollit.
```HTML5
<audio id="meowClip" controls>
<source src="audio/meow.mp3" type="audio/mpeg" />
<source src="audio/meow.ogg" type="audio/ogg" />
</audio>
```
### Extra knowledge
#### Multiple classes
Erotetaan välilyönnillä, pidetään samojen quotejen sisällä
``` html
<img class="class1 class2">
```
#### Tags
HTML5 introduces more descriptive HTML tags. These include **main, header, footer, nav, video, article, section** and others.
These tags give a descriptive structure to your HTML, make your HTML easier to read, and help with Search Engine Optimization (SEO) and accessibility. The main HTML5 tag helps search engines and other developers find the main content of your page.
#### Metadatan käyttäminen ja muutamat tärkeät loitsut
Jos CSS- tiedostossa haluaa käyttää @media- queryja, tulee html-koodin metadataan sisällyttää seuraava osio.
``` html
<meta name="viewport" content="width=device-width, initial-scale=1">
```
## CSS
!important > Inline > ID > Class. Samassa tapauksessa mennään CSS-koodin järjestyksessä.
### HTML:n sisällä style block
``` CSS
<style>
h2 {
color: red;
}
</style>
```
### Absolute ja Relative yksiköt
Relative units, such as **em** or **rem**, are relative to another length value. For example, em is based on the size of an element's font. If you use it to set the font-size property itself, it's relative to the parent's font-size.
### Fontit
``` CSS
alue {
font-size: px, em;
font-family: font1, degradeFont;
}
```
### Taustat
``` CSS
.background{
background.color = color;
}
```
### CSS- blockit
#### Block and inline boxes
On kahden tyyppisiä blockeja, blockit ja inline boxit. Blockit luovat automaattisesti uuden rivin ja inline boxit sijoittuvat blockin sisälle. Jotkin elementit sisältävät itseisarvona blockin tai inline boxin.
Blockit noudattavat width ja height- arvoja ja puskevat muita blockeja pois päin arvojen verran.
Inline- tason elementtien koko on vain niiden contentin kokoinen, jonka vuoksi korkeussuunnassa padding tai border eivät muuta niiden sijoitusta tai kokoa, eikä muiden inline elementtien sijoitusta. Inline- elementit kyllä noudattavat paddingia, marginia ja bordereita, mutta nämä voivat overlapata muiden inline- elementtien kanssa. [Esimerkki](####Esimerkki-inline-boxeista). Poikkeuksena kokojen muuttamiseen ovat elementit, jotka sisältävät korkeus ja/tai leveysarvoja, kuten *img*, joka on luonnostaan inline.
Tämän vuoksi esimerkiksi navigointikenttää luodessa on muistettava, että elementti a on inline box, jonka vuoksi useampi linkki voi overlapata, vaikka niille olisi annettu padding arvoja suurentamaan linkin klikattavaa kokoa. Tällöin linkit kannattaa muuttaa esimerkiksi display: inline-block; muotoon, jolloin ne noudattavat parent boxin sisällä kokoon vaikuttavia arvoja.
Blockeja:
- h1
- p
inline boxeja:
- a
- span
- em
- strong
Kaikkien elementtien perityt arvot löytyvät [w3schoolsista](https://www.w3schools.com/html/html_blocks.asp).
#### Padding
Padding sijaitsee elementin ja borderin välissä ja luo sinne tyhjää tilaa. Padding ei voi olla negatiivinen. Peruslaatikossa padding lisää laatikon kokoa annettujen arvojen verran. Jos laatikon tyyppi on Alternative Box, padding vie tilaa laatikolle annettuista korkeudesta ja leveydestä.
Elementille annettu taustakuva (background) näkyy paddingin alla.
#### Border
Border sijaitsee Marginin ja Padding välissä. Border luo annetujen arvojen mukaisesti reunat, joita voidaan myös teksturoida. Peruslaatikossa Border lisää laatikon kokoa annettujen arvojen verran. Jos laatikon tyyppi on Alternative Box, Border vie tilaa laatikolle annettuista korkeudesta ja leveydestä.
Perusreunat, tässä esimerkissä punainen, 5 pikseliä leveä ja kiinteä.
``` CSS
<style>
.thin-red-border {
border-color: red;
border-width: 5px;
border-style: solid;
}
</style>
```
Reunojen pehmennys. Reunoista ja samalla kuvasta voi tehdä pyöreän käyttämällä pikseleiden sijaan prosentteja, esim. 50%.
``` CSS
border-radius: x px;
```
#### Margin
Margin tekee pidemmän välimatkan ulkopuolisiin muihin objekteihin. Margin toimii samalla tavalla peruslaatikossa ja alternative boxissa.
Asettamalla Margin arvoksi "auto", voidaan elementti keskittää vaakatasossa. Tällä voidaan vaikuttaa myös kuviin, jos niille asetetaan display arvo.
**IMPORTANT:** Jos kahdelle elementille, jotka vaikuttavat pystysuunnassa, on annettu vierekkäiset Margin- arvot, pätee kolme pääsääntöä:
- Kaksi positiivista arvoa ottavat huomioon vain suuremman yksittäisen arvon
- Kaksi negatiivista arvoa ottavat huomioon pienimmän (kauimpana nollasta) arvon
- Jos toinen arvo on negatiivinen, vähennetään se positiivisesta arvosta
#### Perus Boxit ja Alternative Boxit
Perusboxit ovat sisältä päin sen kokoisia kuin niille merkityt inline-size (width) ja block-size (height). Padding ja Border leventävät Boxin kokoa "ulospäin", eli todellisuudessa boxi on isompi kuin merkityt width ja height.
Alternate Boxissa laatikon koko on aina sille merkitty width ja height. "Sisältölaatikon" koosta vähennetään Padding ja Border. Alternate Boxin etuna on se, että sen koko on aina ne arvot mitä sille annetaan, jolloin paddingit ja borderit pitää laskea vain sen sisällä.
Molempien kohdalla Margin puskee "näkyvää" laatikkoa arvojensa verran.
- Box:
``` CSS
.box {
width: x px;
height: x px;
}
```
Lisäämällä padding ja / tai border arvoja, kasvattavat boxin todellista kokoa
- Alternative Box:
``` CSS
.box {
box-sizing: border-box;
}
```
Lisäämällä padding ja / tai border arvoja, poistavat sisäisen "sisältölaatikon" kokoa.
- Esimerkki; Luo kaksi visuaalisesti samankokoista laatikkoa:
``` CSS
.box {
border: 5px solid rebeccapurple;
background-color: lightgray;
padding: 40px;
margin: 40px;
width: 300px;
height: 150px;
}
.alternate {
box-sizing: border-box;
width: 390px;
height: 240px;
}
```
``` html
<div class="box">I use the standard box model.</div>
<div class="box alternate">I use the alternate box model.</div>
```
#### Esimerkki inline boxeista
``` CSS
span {
margin: 20px;
padding: 20px;
width: 80px;
height: 50px;
background-color: lightblue;
border: 2px solid blue;
}
```
``` html
<p>
I am a paragraph and this is a <span>span</span> inside that paragraph. A span is an inline element and so does not respect width and height.
</p>
```
#### Clockwise notation
Jos haluaa asettaa eri valuet kaikkiin neljään suuntaan, voidaan käyttää clockwise notationia, jolla asetetaan myötäpäivään kaikille neljälle suunnalle arvot yhteen padding- muuttujaan. Arvot alkavat ylhäältä.
``` CSS
<style>
.box{
padding: 30px 20px 10px 5px;
}
</style>
```
### Flexbox
Flexboxin ideana on luoda alue, johon voidaan sijoittaa erilaisia osia antaen niille prosentuaalisesti tilaa alueen sisällä.
Flex-itemeille voi asettaa width tai height arvoja, mutta ne voivat kasvaa niiden yli (tai ali) riippuen containerin koosta.
**Termit:**
- Flex-container: Isompi flex-"laatikko", jonka sisään asetetaan osia. Käytettäessä flexin perusasetuksia, flex-itemit eivät koskaan kasva containerille annettujen rajojen yli.
- Flex-item: Osa, joita voidaan asettaa flex-containeriin. Flex-item voi olla myös flex-container.
**Perusmääritys:**
``` CSS
flex-container{
display: flex
}
flex-item{
flex: 1;
}
```
**Flex-shorthand**
flex: flex-grow flex-shrink flex-basis
flex-grow kertoo flex-itemille minkä kokoiseksi itemit voivat kasvaa containerissa verrattuna muihin containerin itemeihin.
flex-shrinkin avulla määritetään millä "kertoimella" itemit kutistuvat, jos itemit eivät mahdu containerille määritettyyn kokoon. Korkeampi numero nostaa kerrointa. 0 tarkoittaa sitä, että kyseinen itemi ei kutistu.
flex-basis asettaa flex-itemille lähtökohtaisen koon. Jos flex-basis on asetettu tiettyyn lukemaan, alkaa grow tai shrink vasta sen lukeman jälkeen. Jos flex-basis on auto, tarkistaa se silloin elementille annetun width tai height arvon.
Important:
kaksi asiaa flex-shorthandista, jotka ovat flex: 1 ja flex: auto.
Flex: 1 asettaa shorthand arvoiksi; 1 1 0.
Flex: auto asettaa shorthand arvoiksi; 1 1 auto.
Lisää erikoisemmista shorthandeista [tässä](https://www.w3.org/TR/css-flexbox-1/#flex-common) linkissä
Hyvä ottaa haltuun myös flex: none. Tällöin elementti tottelee height tai width siihen asti kunnes tilaa ei enää ole containerissa. Esim jos navigointikentässä on kolme nappi, jotka ovat 100px leveydeltä. Voidaan määrittää että n. 330px kohdalla muutetaan napit muunlaiseksi navigoinniksi, siihen asti vähennetään vain vasemmalta tyhjää tilaa, joka on auto. **OBS** Myöhemmin tämän voi tehdä järkevämmin justifylla.
**OBS2** Kikkakakkonen on tehdä tämä niin, että ensimmäinen item sisältää arvon margin-right: auto. Tällöin ensimmäisen itemin oikean puolimmainen margin syö kaiken tarjolla olevan tyhjän tilan.
**Min-width- tietoa**
Joissain tapauksissa containerin sisäiset itemit voivat overflowata, jos containerin koko menee liian pieneksi. Tämä johtuu siitä, että joillain elementeillä on default arvoina tietty width ja height, jolloin ne eivät suostu pienenemään noita arvoja pienemmäksi. Tämän vuoksi joissain tapauksissa on asetettava min-width: 0; jolloin elementit saavat pienentyä poikkeavasti. Esimerkiksi elementin, jossa on tekstiä, default minimileveys on sen pisimmän yhtänäisen sanan mittainen.
**Flex-direction ja Axes**
flex-direction määrittää mihin suuntaan flex-containerin itemit järjestyvät. Atribuutilla column, itemit sijoitetaan containeriin päällekkäin. Default attribuutilla row, itemit sijoitetaan containeriin vierekkäin.
Flex-containerilla on olemassa kaksi axista, main axis ja cross axis. Flex-directionin mukainen axis on main axis ja sen poikittainen on cross-axis. Myös Flex-basis suunta on directionin mukainen.
Defaulttina kaksi sääntöä:
1. Main-axis: Itemit asetetaan alkamaan containerin alun reunalta
2. Cross-axis: Itemit käyttävät koko containerille varatun cross-axis tilan. [Default: Height]
**Alignment- asettelu**
Alignmentit asetetaan lähes aina **flex-containerin** sisälle.
justify-content: liikuttaa itemeitä main axisin suuntaisesti.
align-items: liikuttaa itemeitä cross axisin mukaisesti.
gap: asettaa itemeitten välille raon main-axisin mukaisesti
align-self: Poikkeus, joka vahvistaa säännön. Tämä asetetaan *itemin* sisälle.
### Värityksistä
#### Hexadecimaalien käyttö
Hexadecimaalit määräävät RGB- yhdistelmän käyttämällä kuutta numeroa -- RRGGBB
esim.
#FF0000 -- Punainen
#00FF00 -- Vihreä
#0000FF -- Sininen
Perusvärit voidaan lyhentää ottamalla jokaisesta perusväristä toinen merkintä pois -- RGB
esim.
#F00 -- Punainen
#0F0 -- Vihreä
#00F -- Sininen
#### RGB merkinnän käyttö
RGB- merkinnällä voidaan suoraan kertoa kuinka paljon mitäkin väriä halutaan. 0-255.
RGB(x, y, z)
esim.
RGB(255, 0, 0) -- Punainen
RGB- värityksessä on mahdollista lisätä myös läpinäkyvyys(transparency), jolloin merkintä on RGBA(x,y,z,a). Alpha-value on väliltä 0-1.
#### HSL merkinnän käyttö
Hue, Saturation, Lightness. Ensimmäinen arvo on väliltä 0-360 ja sillä tarkoitetaan kulmaa väriympyrässä. Toisella arvolla lisätään väriin harmautta välillä 0-100%, isommalla arvolla vähemmän harmautta. Kolmas arvo lisää valoisuutta, jolla määritetään paljonko värissä on valkoista ja mustaa. 0% Black - 100% White. 50% on normaali. HUOM! Vain CSS3 ->
HSL(0,100%,50%) -- Punainen
#### Usean värin käyttö
##### Linear Gradient ja Repeating Linear Gradient
Linear gradientin avulla on mahdollista tehdä taustoja käyttäen useita värejä, jotka vaihtuvat annettujen parametrien mukaisesti. Linear gradient on niin moniulotteinen aihe, etten jätä tähän yksittäistä esimerkkiä vaan linkin CSS- dokumentaatioon
[Linear Gradient](https://developer.mozilla.org/en-US/docs/Web/CSS/linear-gradient)
[Repeating Linear Gradient](https://developer.mozilla.org/en-US/docs/Web/CSS/repeating-linear-gradient)
### Eri tapoja nimetä ja valita CSS- elementtejä
#### !Important
Kaikista vahvin tapa kertoa mitä CSS-asetusta tulee käyttää. Lisätään laittamalla attribuutin perään !important.
``` CSS
.white-text{
color: white !important;
}
```
#### Luokat (Classes)
Nimetään käyttämällä pistettä CSS- tiedostossa. HTML- tagina käytetään class="", josta piste poistetaan
``` CSS
<style>
.blue-text {
color: blue;
}
</style>
```
``` html
<p class="blue-text">Tämä teksti olisi sinistä</p>
```
Applying multiple class attributes to a HTML element is done with a space between them like this:
``` CSS
class="class1 class2"
```
Note: It doesn't matter which order the classes are listed in the HTML element.
However, the order of the class declarations in the style section is what is important. The second declaration will always take precedence over the first.
#### ID
Nimetään käyttämällä #- merkkiä CSS- tiedostossa. HTML- tagina käytetään id="", josta # poistetaan. Id on hyvä olla uniikki, vaikka sitä ei ole pakotettu. ID ylikirjoittaa Classin, jos samassa elementissä molemmat.
``` CSS
#cat-photo-element {
background-color: green;
}
```
``` html
<div id="cat-photo-element">
<p> Tässä olisi vihreä tausta</p>
</div>
```
#### Attribute selector
Nimetään laittamalla hakasulkeiden sisään haluttu attribute ja mahdollinen nimitys.
Esim. vaikuttaa kaikkiin elementteihin joista löytyy type="radio"
``` CSS
[type='radio'] {
margin: 20px 0px 20px 0px;
}
```
#### ::Before ja ::After
These pseudo-elements are used to add something before or after a selected element.
For the ::before and ::after pseudo-elements to function properly, they must have a defined content property. This property is usually used to add things like a photo or text to the selected element. When the ::before and ::after pseudo-elements are used to make shapes, the content property is still required, but it's set to an empty string.
Yläluokan asetuksista mm. transform vaikuttaa näihin alempiin luokkiin.
NOTE: Oletan että ne muuttujat joita löytyy yläluokista, mutta joita ei ylikirjoiteta näissä pseudo-luokissa, ovat voimassa
### Muuttujat
Muuttuja on jonkin luokan sisällä (mahd. globaaliudelle) ja ne nimetään käyttämällä tuplaviivaa muuttujan nimen edessä. Kutsuminen tapahtuu kirjoittamalla arvoksi var(--muuttujan-nimi). Hyvänä käytäntönä voidaan pitää sitä, että muuttujia sisältäviin arvoihin lisätään fallback- taso, eli perään jokin default- arvo.
Esim.
```CSS
<style>
.luokka{
--color-muuttuja: orange;
--fonttikoko-muuttuja: 12px;
}
.luokka-h1{
color: var(--color-muuttuja, white);
font-size: 14px;
}
.luokka-p{
color: black;
font-size: var(--fonttikoko-muuttuja, 13px);
}
.luokka-yhdistelma{
color: var(--color-muuttuja, blue);
font-size: var(--fonttikoko-muuttuja, 11px);
}
</style>
```
Globaalit muuttujat lisätään ns. :root- pseudo-luokan alaisuuteen ja niitä voidaan käyttää missä tahansa CSS-koodissa.
``` CSS
<style>
:root {
--globaali-muuttuja: blue;
}
.sininen-teksti{
color: var(--globaali-muuttuja);
}
</style>
```
Globaaleja muuttujia voidaan muuttaa koodin mennessä eteenpäin niin etteivät aikaisemmat delkaraatiot muutu.
``` CSS
<style>
:root {
--globaali-muuttuja: blue;
}
.sininen-teksti{
color: var(--globaali-muuttuja);
}
.punainen{
--globaali-muuttuja: red;
}
.punainen-teksti{
color: var(---globaali-muuttuja)
}
</style>
```
### @media- käyttäminen
Jos CSS- koodissa halutaan ottaa huomioon erilaisten päätteiden koot, voidaan käyttää @media- toimintoa, jonka avulla voidaan määrittää eri kokoisille päätteille omat muuttujat.
Esim.
``` CSS
<style>
:root {
--leipateksti-fonttikoko: 16px;
}
@media (max-width: 250px){
--leipateksti-fonttikoko: 12px;
}
</style>
```
### Browser fallbacks
Sellaisissa tapauksissa joissa käytetään monimutkaisempaa CSS- koodia, voi vanhemmissa selaimissa tulla vastaan ongelmia. Tälläisiä tilanteita voidaan ennakoida käyttämällä ns. fallback- vaihtoehtoja, joissa koodiin lisätään yleisemmin käytetty vaihtoehto monimutkaisemman yläpuolelle.
Tämä esimerkki on suoraan freecodecamp.org css-oppitunnilta, jossa taustaväri määritetään käyttämällä muuttujaa. Muuttujia ei tueta ollenkaan Internet Explorerissa, minkä vuoksi koodiin on lisätty ylimääräinen fallback- vaihtoehto.
``` html css
<style>
:root {
--red-color: red;
}
.red-box {
background: red;
background: var(--red-color);
height: 200px;
width:200px;
}
</style>
<div class="red-box"></div>
```
### Helppo tapa tehdä responsiivinen kuva / alue
```css
img {
max-width: 100%;
height: auto;
}
```
### Viewport sizes
The four different viewport units are:
- vw (viewport width): 10vw would be 10% of the viewport's width.
- vh (viewport height): 3vh would be 3% of the viewport's height.
- vmin (viewport minimum): 70vmin would be 70% of the viewport's smaller dimension (height or width).
- vmax (viewport maximum): 100vmax would be 100% of the viewport's bigger dimension (height or width).
## Advanced visual options
Tähän osioon lisään itselleni uusia tapoja luoda visuaalisia elementtejä websivuille.
### CSS Flexbox
flex-direction muuttaa mihin suuntaan uudet elementit sijoittuvat flex- containerin sisällä
```css
#id{
display: flex;
flex-direction: row; // Default
}
```
### CSS Grid
Gridit tekevät asetetuista elementeistä ns. grid- elementtejä. Kaikki muut sitova osio on nimeltään container, ja containerin sisäiset elementit ovat itemeitä.
#### Perusasetus
```css
.container{
display:grid;
}
```
#### Gridin hyväksymät arvot
You can use absolute and relative units like *px and em* in CSS Grid to define the size of rows and columns. You can use these as well:
*fr*: sets the column or row to a fraction of the available space,
*auto*: sets the column or row to the width or height of its content automatically,
*%*: adjusts the column or row to the percent width of its container.
##### FR, eli fractions
fr- avainsanalla annetaan objektille sellainen koko joka vastaa sitä kuinka monta fractionia sille on annettu.
Tilanteessa jossa kenttien koot on määrätty niin että kaksi kenttää saavat kokonsa niiden contentin perusteella (auto) ja yksi saa fractionien avulla, fractionoitu alue täyttää kaiken muun tilan.
Tilanteissa joissa käytössä on useampia fractioneita, ne jakavat käytössä olevan alueen niille annetun arvon mukaan
#### Grid-template-columns
Tämä asettaa containerille tietyn määrän pylväspalkkeja, johon containerin itemit asetetaan. Lukumäärät muuttujan sisällä kertovat kuinka monta osaa tehdään ja kuinka leveitä ne ovat. Huomioi: Ei pilkkuja!
```css
.container{
grid-template-columns: 50px 50px 50px;
}
```
#### Grid-template-rows
ks. yläpuolelta. Tämä tekee jonoja
```css
.container{
grid-template-rows: 50px 50px 50px;
}
```
#### Repeat
Jos rivejä tai pylväitä on useampia samankokoisia, voidaan toistoa rajoittaa käyttämällä avainsanaa repeat.
```css
.container{
grid-template-columns: repeat(3, 50px); /* Luo kolme 50px pylvästä */
}
```
```css
.container{
grid-template-columns: repeat(2, 20px) 40px; /*Translate: 20px 20px 40px;*/
}
```
#### Minmax, eli minimi ja maksimikoot
Tällä avainsanalla voidaan määrittää minimi- ja maksimikoot itemeille. Erilaisia kenttiä voidaan lisätä kuten yläpuolella olevassa koodiesimerkissä.
```css
.container{
grid-template-columns: minmax(20px, 100px); /* Luo kentän joka on min 20px ja max 100px */
}
```
#### Grid-column-gap ja row-gap
Asettaa itemeiden välille halutun kokoisen raon.
```css
.container{
grid-column-gap: 10px;
grid-row-gap: 10px;
}
```
Shorthandina voidaan käyttää pelkästään Grid-gap. Tämä asettaa yhdellä arvolla molempiin samat lukemat. Jos annetaan kaksi arvoa, ensimmäinen on row ja toinen column gap.
```css
.container{
grid-gap: 10px 20px;
}
```
#### Column ja Row lines
Column ja row lineseilla tarkoitetaan jakoviivoja joilla container on jaettu. Ensimmäinen linja kulkee ensimmäisen elementin yläpuolella (row) tai vasemmalla (column) puolella. Esimerkiksi kolmella columnilla on neljä column linea.
|Column|Column|Column|
__
Row
__
Row
__
Row
__
#### Grid-column
Käyttökohde: Grid Items
Tällä asetetaan kuinka monta column linea haluttu itemi käyttää gridistä. Alla oleva esimerkki käyttää ensimmäisestä linjasta kolmanteen linjaan, eli kaksi columnia.
```css
.item{
grid-column: 1 / 3
}
```
#### Grid-row
ks. ylempi. Tämä roweilla.
```css
.item{
grid-row: 1 / 3
}
```
#### Auto-fill
Auto-fillin avulla containeriin lisätään niin monta riviä ja pylvästä kuin sen kokoon mahtuu annettujen parametrien avulla. Auto-fill luo tyhjiä cellejä, jos tilaa on enemmän kuin omia cellejä.
```css
.container{
grid-template-columns: repeat(auto-fill, minmax(60px, 1fr));
}
```
#### Auto-fit
Auto-fit venyttää cellejä annettujen parametrien mukaan, jos pituus siinä suunnassa ylittyy. Jos kaikki omat cellit eivät mahdu, luodaan uusi rivi / pylväs.
```css
.container{
grid-template-columns: repeat(auto-fit, minmax(60px, 1fr));
}
```
____
#### Moving content inside cells
Jokaisen itemin ympärillä kulkee kuvitteellinen laatikko, jota kutsutaan celliksi. Cellien sisällä voi olla jotain contenttia. Contenttia voidaan manipuloida seuraavilla tavoilla
#### Justify-self
Tällä asetetaan kuinka paljon leveyttä cellistä content käyttää. Defaulttina tämä on Stretch, joka venyttää contentin koko cellin kokoiseksi (esim. taustakuva).
start: aligns the content at the left of the cell,
center: aligns the content in the center of the cell,
end: aligns the content at the right of the cell.
```css
.item{
justify-self: center;
}
```
#### Align-self
ks. ylempi, mutta pystysuunnassa.
```css
.item{
align-self: center;
}
```
#### Justify-items ja align-items
Tällä annetaan sääntöjä kaikille containerin itemeille.
```css
.container{
justify-items: center;
align-items: center;
}
```
___
#### Grid-template-areas
Tällä voidaan nimetä kenttiä, esimerkiksi sen sisältämän contentin mukaan. Nimeämällä osat samannimiseksi, asetetaan useampi cell arean käyttöön. Käyttämällä pistettä, asetetaan cell tyhjäksi kentäksi.
```css
.container{
grid-template-areas:
"header header header"
"advert content content"
"footer footer footer";
}
```
#### Grid-area
Tämän avulla jokin itemi voidaan sisällyttää arean sisälle. Jos kyseisellä nimellä on useampia kenttiä varattuna areassa, käyttää itemi koko tämän tilan.
```css
item1 {
grid-area: header;
}
```
Grid-area ei vaadi template areaa, vaan areat voidaan tehdä lennosta käyttämällä row ja column lineja.
```css
grid-area: horizontal line to start at / vertical line to start at / horizontal line to end at / vertical line to end at;
```
#### Simppeli responsiivisuus sivuille käyttämällä @Media
Käyttämällä Media queryja, voidaan luoda simppelillä tavalla responsiivisuutta sivuille antamalla eri alueita (grid-area), sitä mukaan minkä kokoinen toistoalue on.
```css
@media (min-width: 300px){
.container{
grid-template-columns: auto 1fr;
grid-template-rows: auto 1fr auto;
grid-template-areas:
"advert header"
"advert content"
"advert footer";
}
}
@media (min-width: 400px){
.container{
grid-template-areas:
"header header"
"advert content"
"footer footer";
}
}
```
### Positions
#### Relative
Jos objekti asetetaan relative- tilaan, liikkuu elementti pois päin merkittyjen arvojen verran. Tärkeä huomio on se, että tämä ei liikuta muita elementtejä, eli huolimattomuudella on mahdollista asettaa elementtien näkyviä osia päällekkäin. Tälläistä liikuttamista kutsutaan offsetiksi. Alapuolella oleva koodi liikuttaa kaikkia p-elementtejä 10px ylöspäin, eli ns. bottom offset.
```CSS
p {
position: relative;
bottom: 10px;
}
```
#### Absolute
Absolute- tilassa elementti lukitaan paikoilleen relatiivisesti sen parent- elementtiin. Absolute- tilassa elementti poistetaan dokumentin luonnollisesta flow:sta, minkä vuoksi on tärkeää että sen parent- elementti on *positioned*. Absolute- tilassakin voidaan käyttää offset-arvoilla liikuttamista. **Tärkeä huomio on se että elementin parent- elementti määräytyy HTML- hierarkian mukaan!**
```html
.laatikko{
position: relative;
}
#laatikon-sisalla{
position: absolute;
}
<h1>Hello world!</h1>
<div class="laatikko">
<p id="laatikon-sisalla">Tämän lauseen elementti on sidonnainen sen parent- elementistä, joka on ympäröivä div-elementti</p>
</div>
```
#### Fixed
Fixed- tilassa elementti lukitaan selaimen ikkunan mukaisesti ja se poistetaan kokonaan dokumentin flow:sta. Tämä tarkoittaa sitä että objektit pysyvät ruudulla samassa paikassa kun sivustoa esimerkiksi rullataan johonkin suuntaan. Tällä voi tehdä helposti esimerkiksi pysyvän navigointikentän, kunhan ottaa huomioon sen viemän tilan muissa kentissä.
```css
#navbar {
position: fixed;
top: 0px;
left: 0px;
width: 100%;
background-color: #767676;
}
```
#### Float
Floatin avulla elementti voidaan asettaa parent- elementin sisällä joko vasemmalle tai oikealle. Elementille annetaan leveysarvo, jolla määritetään paljonko tilaa nämä elementit vievät.
```css
#left {
float: left;
width: 50%;
}
#right {
float: right;
width: 40%;
}
```
#### z-index
Z-indexin avulla on mahdollista vaikuttaa siihen mitkä elementit ovat ns. päällimmäisiä. Korkeampi arvo vastaa korkeampaa asemaa. Normaalisti päällimmäisyys määräytyy sen mukaan missä järjestyksessä elementit ovat HTML- koodissa.
```css
z-index: 2;
```
### Box-shadow
The box-shadow property applies one or more shadows to an element.
The box-shadow property takes values for
* offset-x (how far to push the shadow horizontally from the element),
* offset-y (how far to push the shadow vertically from the element),
* blur-radius,
* spread-radius and
* color, in that order.
The blur-radius and spread-radius values are optional.
Tämä lisää kaksi box-shadow elementtiä.
``` CSS
box-shadow: 0 10px 20px rgba(0,0,0,0.19), 0 6px 6px rgba(0,0,0,0.23);
```
### Opacity
Tämän avulla hallitaan koko halutun elementin läpinäkyvyyttä. Väliltä 0-1.
``` CSS
Opacity: 0.5;
```
### Using pseudo-classes
Pseudo-luokilla voidaan valita elementti kun se on jossakin tietyssä tilassa. Pseudoluokka erotetaan käyttämällä kaksoispistettä ja merkitsemällä tila tämän jälkeen. Esimerkiksi tällä koodilla h1- tason otsikot muuttuvat punaisiksi kun hiiri on jonkin h1-elementin päällä (hover-state).
``` CSS
h1:hover{
font-color: red;
}
```
### Transform -- Scale, skewX Y Z, rotation
Tuplaa kaikkien paragraphien koot
```CSS
p {
transform: scale(2);
}
```
"Viistouttaa" halutun akselin ympäri haluttu määrä
```CSS
p {
transform: skewX(Xdeg);
}
```
Kääntää elementtiä halutun määrän
```CSS
div {
transform: rotation(Xdeg);
}
```
### Animaatiot
The animation properties control how the animation should behave and the **@keyframes** rule controls what happens during that animation.
**animation-name** sets the name of the animation, which is later used by @keyframes to tell CSS which rules go with which animations.
**animation-duration** sets the length of time for the animation.
**animation-fill-mode** asettaa mihin tilaan animaatio päättyy, merkittävä keyword forwards jolloin animaatio päättyy päätöstilaan
**animation-iteration-count** asettaa kuinka monesti animaatio toistetaan, numero tai infinite.
**animation-timing-function** asettaa millaisella nopeudella (speed curve) animaatio suoritetaan; ease, ease-out(nopea alku), ease-in(nopea loppu), linear
```CSS
#anim {
animation-name: animationName;
animation-duration: Xs;
}
@keyframes animationFrame {
0% {
background-color: blue;
}
100% {
background-color: yellow;
}
}
```
Tällä voi luoda esimerkiksi hienoja animaatioita painikkeisiin hover-efektin kautta:
NOTE: Käyttämällä animation-fill-mode: forwards asetetaan tila pysymään hoverin aikana päätöstilaan
```CSS
<style>
img:hover {
animation-name: width;
animation-duration: 500ms;
animation-fill-mode: forwards;
}
@keyframes width {
100% {
width: 40px;
}
}
</style>
```
##### Bezier curves
In CSS animations, Bezier curves are used with the cubic-bezier function. The shape of the curve represents how the animation plays out. The curve lives on a 1 by 1 coordinate system. The X-axis of this coordinate system is the duration of the animation (think of it as a time scale), and the Y-axis is the change in the animation.
Bezier curve koostuu neljästä pisteestä, joista kaksi ensimmäistä sijaitseva origoissa (0,0) ja (1,1). Koodiin kirjataan kaksi muuta pistettä, jotka muodostavat animaatiolle itse tehdyn käyrän.
```CSS
animation-timing-function: cubic-bezier(x1, y1, x2, y2);
```
### Shapes
Tähän sisällytän valmiita CSS- koodeja, joilla voi tehdä erilaisia graafisia muotoja
##### Crescent Moon
```CSS
<style>
.center {
position: absolute;
margin: auto;
top: 0;
right: 0;
bottom: 0;
left: 0;
width: 100px;
height: 100px;
background-color: transparent;
border-radius: 50%;
box-shadow: 25px 10px 0px 0px blue;
}
</style>
```
##### Heart
```CSS
<style>
.heart {
position: absolute;
margin: auto;
top: 0;
right: 0;
bottom: 0;
left: 0;
background-color: pink;
height: 50px;
width: 50px;
transform: rotate(-45deg);
}
.heart::after {
background-color: pink;
content: "";
border-radius: 50%;
position: absolute;
width: 50px;
height: 50px;
top: 0px;
left: 25px;
}
.heart::before {
content: "";
background-color: pink;
border-radius: 50%;
position: absolute;
width: 50px;
height: 50px;
top: -25px;
left: 0px;
}
</style>
```
### Kuinka tehdä järkevät line-breakit (rivinvaihto) elementeille
Accessibilityn kannalta ei ole järkevää käyttää `<br>`- tagia rivinvaihtoihin elementtien välillä, koska screenreaderit eivät osaa tulkita näitä välttämättä oikealla tavalla. Myös CSS- koodin käyttäminen vaikeutuu. Parempi tapa on käyttää block- tyyppisiä display asetuksia tyylien tasolla.
Esimerkissä annetaan formissa ohjeistus, jossa kentän otsikko on block- tyyppinen, jolloin se käytännössä muodostaa uuden rivin. Tässä tapauksessa jokainen label- kenttä on yksi laatikko, joka täyttää koko rivin.
```css
label {
display: block;
margin-top: 0.8rem;
}
input {
margin-top: 0.1rem;
}
```
## Accessibility
### Article, section, div
**Note about section and div**
The section element is also new with HTML5, and has a slightly different semantic meaning than article. An article is for standalone content, and a section is for grouping thematically related content. They can be used within each other, as needed. For example, if a book is the article, then each chapter is a section. When there's no relationship between groups of content, then use a div.
```html
<div> - groups content
<section> - groups related content
<article> - groups independent, self-contained content
```
### Figure ja figcaption
```html5
<figure>
<img src="roundhouseDestruction.jpeg" alt="Photo of Camper Cat executing a roundhouse kick">
<br>
<figcaption>
Master Camper Cat demonstrates proper form of a roundhouse kick.
</figcaption>
</figure>
```
### Label
The label tag wraps the text for a specific form control item, usually the name or label for a choice. This ties meaning to the item and makes the form more readable. The for attribute on a label tag explicitly associates that label with the form control and is used by screen readers.
The value of the for attribute must be the same as the value of the id attribute of the form control. Here's an example:
```html5
<form>
<label for="name">Name:</label>
<input type="text" id="name" name="name">
</form>
```
### Fieldset ja legend
The fieldset tag surrounds the entire grouping of radio buttons to achieve this. It often uses a legend tag to provide a description for the grouping, which is read by screen readers for each choice in the fieldset element.
The fieldset wrapper and legend tag are not necessary when the choices are self-explanatory, like a gender selection. Using a label with the for attribute for each radio button is sufficient.
Here's an example:
``` html5
<form>
<fieldset>
<legend>Choose one of these three items:</legend>
<input id="one" type="radio" name="items" value="one">
<label for="one">Choice One</label><br>
<input id="two" type="radio" name="items" value="two">
<label for="two">Choice Two</label><br>
<input id="three" type="radio" name="items" value="three">
<label for="three">Choice Three</label>
</fieldset>
</form>
```
### Date
For older browsers, the type will default to text, so it helps to show users the expected date format in the label or as placeholder text just in case.
Here's an example:
```html5
<label for="input1">Enter a date:</label>
<input type="date" id="input1" name="input1">
```
### Time ja datetime
Näiden avulla screenreader lukee datetimen sisälle asetetun päivämäärän selkeyden vuoksi
```html5
<p>Master Camper Cat officiated the cage match between Goro and Scorpion <time datetime="2013-02-13">last Wednesday</time>, which ended in a draw.</p>
```
### Accesskey
Accesskey on uusi avainsana html5:ssä. Sen avulla elementille voidaan asettaa jokin painike, jonka avulla elementistä tulee interaktiivinen
```html5
<button accesskey="b">Important Button</button>
```
### Tabkey
Tabkey avainsanalla on mahdollista asettaa muitakin elementtejä, kuin vain ne jotka ottavat vastaan napinpainalluksia, sellaisiksi elementiksi joihin selain pysähtyy kun käyttäjä etsii tekstikenttiä tab-painikkeella. Input-kentät ovat normaalisti valmiiksi sellaisia joihin aktiivinen kenttä pysähtyy tabia käytettäessä.
Käyttämällä korkeampia numeroita, asetetaan tabindex-objekteille läpikäyntijärjestys. Ensimmäisenä käydään läpi numeroidut objektit 1:stä eteenpäin, minkä jälkeen käydään läpi default ja 0- arvoiset.
HUOM! Tabindexin käyttö mahdollistaa CSS:sä pseudoluokan :focus käytön!
```html5
<div tabindex="0">I need keyboard focus!</div>
```
### Using CSS
#### .sr-only, perusasetukset
CSS- koodin avulla on mahdollista lisätä sivustolle contenttia, jotka ovat nähtävissä vain screenreaderilla, eli tavalliset selaimet ignoraavat.
HUOM! Contenttia ei saa asettaa näkymättömäksi tai piilottaa tiputtamalla kokoa tai asettamalla display tai visibility arvoja nollaan. Tällä vain siirretään contentti "ulos" selaimen ruudusta
```css
.sr-only {
position: absolute;
left: -10000px;
width: 1px;
height: 1px;
top: auto;
overflow: hidden;
}
```
#### Kontrastien käyttö tekstien selkeyttämiseksi
The Web Content Accessibility Guidelines (WCAG) recommend at least a 4.5 to 1 contrast ratio for normal text. The ratio is calculated by comparing the relative luminance values of two colors. This ranges from 1:1 for the same color, or no contrast, to 21:1 for white against black, the strongest contrast. There are many contrast checking tools available online that calculate this ratio for you.
Color is a large part of visual design, but its use introduces two accessibility issues. First, color alone should not be used as the only way to convey important information because screen reader users won't see it. Second, foreground and background colors need sufficient contrast so colorblind users can distinguish them.
Esimerkki [työkalu](https://webaim.org/resources/contrastchecker/)