- oddělení vzhledu stránky od obsahu - přizpůsobení prezentace pro rozdílná zařízení (displej vs. tisk, velikost zobrazovací plochy...)
- postupná specifikace jednotlivých vlastností, kaskádovost specifikací
- atribut style
- styly definované přímo u konkrétních elementů
- nejjednodušší, ale postrádáme oddělení stylů od obsahu (se všemi důsledky)
<span style="color:red;">červený text</span>
- element style
- začlenění stylů přímo do obsahu stránky (na "jednom" místě)
- možnost využití direktivy @import
<style type="text/css"> @import url("adresa");</style>
- element link
- připojení externích zdrojů ke stránce (nejen styly, ale také favicon, RSS atd.)
- možnost definice atributu media
<link rel="stylesheet" type="text/css" href="/URL adresa" media="screen,print" />
selektor {
vlastnost1:hodnota1;
vlastnost2:hodnota2;
}
- selektorů lze uvádět více najednou (oddělují se čárkou)
- stejný selektor lze uvést na více místech
Druh výběru | Příklad | Komentář |
---|---|---|
na základě značky | p | vybere všechny elementy |
na základě třídy | .trida | vybere všechny elementy, které mají v atributu class hodotu trida |
dle ID | #prvni | "vybere pouze prvek, který má id=""prvni""" |
selektor následníka | p img | vybere všechny elementy , které jsou zároveň v elementu (či v některém z elementů, které jsou do něj vnořené) |
pseudotřída | :hover | výběr na základě pseudotřídy umožňuje ovlivnit CSS dle aktivity či pozice na stránce |
všechny elementy | * | |
selektor dítěte | p>a | vybere všechny elementy, které jsou přímo vnořené do daného elementu |
selektor sourozence | A + B | vybere všechny elementy B, které mají stejného rodiče jako A a zároveň po něm přímo následují |
výběr dle atributu | A[attr=hodnota], A[attr] | vybere elementy, které odpovídají nastavení daného atributu |
- atributy class a id
- preferovány vlastnosti "přesnějších" selektorů (výjimku tvoří použití direktivy !important)
- pseudotřídy: :hover, :link, :active, :visited, :first-child, :nth-child(n), :not(selector)
- pseudoelementy: ::first-letter, ::first-line, ::before, ::after, ::selection
- viz http://www.w3schools.com/css/css_pseudo_elements.asp
- vlastnost color
- způsoby určení barvy v rámci stylů:
- pojmenované barvy - např. black, red, blue, white...
- zápis hexa kódem - např. #000000, #0000ff
- při opakování stejných hodnot lze použít zkrácený zápis: #00ff11 = #0f1
- rgb zápisem - např. rgb(0,0,0), rgb(0,0,255)
- rgba zápisem - např. rgba(0,0,0,0.8), rgba(0,0,255,0.2)
p { color: red; }
-
font-family
- typ písma, více hodnot oddělujeme čárkou, použije se první nalezené písmo
- lze použít také písmo načtené z webu
- písma vhodná pro použití na webu... (patková vs. bezpatková, rozšířené typy písem), web safe fonts
p{font-family:"Times New Roman", Times, serif;}
-
font-size
- absolutní (px, pt) či relativní jednotky (em, %)
- při stejné velikosti nejsou všechny typy písem stejně velké! (např. Verdana vs. Calibri)
p{font-size:14px;}
-
font-style
- sklon písma
- normal | italic | oblique
-
font-weight
- tučnost písma
- normal | bold | (bolder | lighter | číslo z množiny {100, 200, 300, 400 ... 900})
-
font-variant
- normal | small-caps
- Co jsou to kapitálky?
- text-align
- zarovnání textu
- left | center | right | justify
- Jak zarovnávat text na webu?
- text-decoration
- "dekorace" textu
- none | underline | overline | line-through
- Jde zařídit, aby byl text najednou podtržený i přeškrtnutý?
- text-transform
- transformace velikosti písmen (vhodnější, než např. psát nadpisy rovnou velkými písmeny)
- none | uppercase | lowercase | capitalize
- text-indent
- odsazení prvního řádku textu
- text-shadow
text-shadow: h-shadow v-shadow blur-radius color|none|initial|inherit;
- letter-spacing
- "prostrkávání" textu (mezery mezi písmeny)
- dříve používané u psacích strojů, nelze psát do obsahu stránek přímo mezery!
- line-height
- výška řádků
Ačkoliv dílčí vlastnosti začínají na "text-", nelze použít souhrnnou vlastnost "text".
Pozadí určujeme pomocí CSS vlastnosti background, instrukce lze zapsat buď hromadně, či v rámci jednotlivých dílčích vlastností.
- background-color
- barva pozadí (všechny podporované formy zápisu)
- background-image
body{ background-image:url('paper.gif'); }
- background-repeat
- opakování obrázku na pozadí
- no-repeat | repeat | repeat-x | repeat-y
- background-position
- umístění obrázku na pozadí
- pozice určena pomocí klíčových slov (top,bottom,left,right,center), či pomocí "souřadnic"
- lze určit pouze jednu, či obě dvě souřadnice (např. "top center")
- background-attachment
- fixace obrázku na pozadí (bez posouvání při rolování daného elementu)
- scroll | fixed
- CSS3 podporuje pozadí v podobě barevného přechodu - Gradient generator
- jednoduché barevné pozadí neřešíme obrázkem!
- dle specifikace lze zapsat více pozadí najednou (specifikace oddělujeme čárkami) - pozor na podporu v prohlížečích
-
každý blokový element na webu má 3 rámečky: padding, border a margin
-
border
- viditelný rámeček (použitelný u blokových i inline elementů)
- border-style
- none | solid | dotted | dashed | double | groove | ridge | inset | outset
- border-width
- border-color
h1{ border: 1px solid red; }
- viditelný rámeček a jeho dílčí vlastnosti lze určovat také jen pro některé strany
- border-top, border-right, border-bottom, border-left
- border-left-color,...
- možnost určení vlastností pro dílčí strany vícenásobným zápisem (ale nepříliš přehledně) - např.:
p{ border-style: dotted solid double dashed;}
-
padding
- volný prostor mezi viditelným rámečkem a obsahem
- lze určovat pro všechny strany najednou, či pro jednotlivé strany zvlášť (vícenásobným zápisem či dílčími vlastnostmi)
padding: 10px; padding: 20px 10px 20px 10px; padding: 20px 10px; padding-top: 20px;
-
margin
- volný prostor mezi viditelným rámečkem a vykreslením dalších elementů
- zápis stejným způsobem, jako padding
- při nastavení marginu zleva i zprava na auto dojde k vycentrování obsahu
div { margin: 0 auto; }
- Měla by stránka vypadat při všech způsobech zobrazení stejně? Jak by měla vypadat stránka při tisku?
- pomocí stylů lze jednoduše zařídit, že se budou používat jiné instrukce v rámci zobrazení na počítači, jiné na mobilu a jiné při tisku
- v rámci CSS3 lze používat také dotazy na velikost
- volba pomocí atributu media při připojení stylů pomocí elementu link
<link rel="stylesheet" media="mediatype and|not|only (expressions)" href="print.css" />
- volba pomocí media query přímo v rámci CSS zápisu
@media not|only mediatype and (expressions) { CSS-Code; }
- typ média: all | screen | print | speech
@media screen and (min-width: 480px) {
body {
background-color: lightgreen;
}
}
- v HTML5 je k dispozici celá řada nových elementů, kterými můžeme článku rozlišit na jednotlivé významové celky
- pozor, ne všechny elementy jsou podporovány ve všech prohlížečích!
- kromě nových elementů je povolena také zjednodušená syntaxe a jsou podporována nová javascriptová API
- header - hlavička stránek, záhlaví článku/sekce
- footer - patička stránek,
- nav - navigace
- main - hlavní obsah stránek (v podstatě jde o sekci, o které zároveň řekneme, že je hlavní; může být na stránce jen jednou)
- section - sekce (stránek, článku atp.) - v zásadě určené pro rozdělení obsahů se stejnou důležitostí
- aside - doplňkový obsah (typicky nějaké další informace, které můžeme vynechat a hlavní obsah pořád dává smysl; nejde o tag jen pro reklamy!)
- article - článek - ucelený textový obsah (má smysl i v případě, pokud bychom ho vyjmuli ze stránky a četli samostatně)
- address - zvýraznění pro
- details - doplňkové informace, které si může uživatel volitelně zobrazit (viditelný text se umisťuje do vnořené značky summary); nepodporováno v IE
- wbr - nepárový tag, kterým prohlížeči umožníte zalomení velmi dlouhého slova, které se nevejde na jeden řádek
- změna v úrovních nadpisů - teoreticky můžeme v každé sekci/článku začínat od úrovně h1, v praxi kvůli vyhledávačům začínáme od h2
- sémantický význam pro elementy b a i
- nové značky figure, canvas, svg, audio, video
- nové typy formulářových polí, validace regulárními výrazy atd.
- budeme probírat na 5. cvičení - multimédia a na 10. cvičení - formuláře...
- pokud prohlížeč nezná značky, které chceme použít, pak neví, jak je vykreslit
- nejde jen o vyloženě staré prohlížeče, např. main či details mají problém i v relativně nových IE/Edge
- nejvhodnější variantou je doplnit na stránky skript pro staré verze IE a případně doplnit styly pro značky, které prohlížeče plošně nepodporují
<!--[if lt IE 9]>
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/html5shiv/3.7.3/html5shiv.min.js"></script>
<![endif]-->
<style>
header, section, footer, aside, nav, main, article, figure {
display: block;
}
</style>