Slide 1

Slide 1 text

Efektivní stylování a best practices

Slide 2

Slide 2 text

1) Trochu historie 2) co bylo před CSS 3) Nástup CSS 4) Komplikace s CSS spojené 5) Metodologie a architektury 6) Co na to JavaScript?

Slide 3

Slide 3 text

Jak efektivně uchopit design na webu? Problém Konkrétní řešení

Slide 4

Slide 4 text

Dr. Håkon Wium Lie

Slide 5

Slide 5 text

E-mailová komunikace http://1997.webhistory.org/www.lists/www-talk.1994q1/0648.html

Slide 6

Slide 6 text

No content

Slide 7

Slide 7 text

Co bylo před tím, než přišlo CSS?

Slide 8

Slide 8 text

ViolaWWW

Slide 9

Slide 9 text

Space Jam

Slide 10

Slide 10 text

Space Jam Barevnost Layout

Slide 11

Slide 11 text

Space Jam - barvy

Slide 12

Slide 12 text

Space Jam – barvy

Slide 13

Slide 13 text

Space Jam – layout

Slide 14

Slide 14 text

Space Jam – layout ... ...


Press Box Shuttle

Slide 15

Slide 15 text

CSS přicházelo s dalším řešením layoutu Float-based layout Flexbox-based layout Grid layout

Slide 16

Slide 16 text

Float-base layout

Slide 17

Slide 17 text

Flexbox base layout

Slide 18

Slide 18 text

Grid layout

Slide 19

Slide 19 text

Grid layout

Slide 20

Slide 20 text

Nástup CSS a vznikající problémy

Slide 21

Slide 21 text

Nástup CSS a vznikající problémy Revoluce

Slide 22

Slide 22 text

Eric A. Meyer

Slide 23

Slide 23 text

CSS: The Definitive Guide

Slide 24

Slide 24 text

První ukázky CSS BODY { font-family: serif; background-color: silver; } H1 { font: x-large Verdana, sans-serif; color: olive; border-bottom: thin black solid; } TABLE { margin: 0; } .sidebar { background-color: olive; padding: 0.5em; } .sidebar UL LI { list-style-type: none; margin-left: 0; margin-right: 0.5em; } .sidebar UL LI A { color: #ffcccc; } .body { background: white no-repeat center url(http://www.mysite.org/pix/logo.gif); }

Slide 25

Slide 25 text

Jedna změna p { padding-bottom: 10px; color: blue; } Homepage paragraph Category paragraph Product detail paragraph

Slide 26

Slide 26 text

Vznikající komplikace Komplikace Komplexnost

Slide 27

Slide 27 text

No content

Slide 28

Slide 28 text

Komplikace s udržitelností Udržitelnost Přímočarost jazyka

Slide 29

Slide 29 text

No content

Slide 30

Slide 30 text

Nejčastější chyby

Slide 31

Slide 31 text

Hluboké zanořování selektorů a vysoká specificita Tvorba prvku Grafické zadání

Slide 32

Slide 32 text

No content

Slide 33

Slide 33 text

No content

Slide 34

Slide 34 text

Nic nefunguje

Slide 35

Slide 35 text

No content

Slide 36

Slide 36 text

Jaké jsou teď možnosti úpravy? Zvýšit speficičnost Upravit blokující selektor !important

Slide 37

Slide 37 text

Jediná vhodná možnost vyřešení problému

Slide 38

Slide 38 text

Čeho jsme docílili? Vytvořen nový selektror, který se nedá dál použít

Slide 39

Slide 39 text

Nesting hell Nástup preprocessorů a možnost zanořování

Slide 40

Slide 40 text

No content

Slide 41

Slide 41 text

Jak bude vypadat překompilovaný soubor?

Slide 42

Slide 42 text

No content

Slide 43

Slide 43 text

Jak bychom měli zanořovat?

Slide 44

Slide 44 text

Kaskáda — pořadí zápisu pravidel a struktura souborů Na pořadí záleží

Slide 45

Slide 45 text

Přiklad

Slide 46

Slide 46 text

No content

Slide 47

Slide 47 text

No content

Slide 48

Slide 48 text

No content

Slide 49

Slide 49 text

Metodologie a architektury CSS

Slide 50

Slide 50 text

Od roku 2008 začali vznikat první pokusy OOCSS SMACSS SUITCSS BEM ITCSS CUBE CSS

Slide 51

Slide 51 text

Smysl metodologií a architektur udržitelnost rozšiřitelnost boj s CSS problémy

Slide 52

Slide 52 text

OOCSS OOCSS definuje objekt jako vizuální vzor, který je znovupoužitelný napříč aplikací

Slide 53

Slide 53 text

Oddělení vzhledu od struktury Oddělení obsahu a kontejneru

Slide 54

Slide 54 text

Oddělení vzhledu od struktury

Slide 55

Slide 55 text

Oddělení obsahu a kontejneru

Slide 56

Slide 56 text

SMACSS Hlavní myšlenkou SMACSS je kategorizace systému pravidel CSS

Slide 57

Slide 57 text

Base

Slide 58

Slide 58 text

Layout

Slide 59

Slide 59 text

Module

Slide 60

Slide 60 text

State

Slide 61

Slide 61 text

BEM

Slide 62

Slide 62 text

Největší výhody Vytváří selektory nejnižší specifičnosti Jednotnost pro větší vývojářské týmy

Slide 63

Slide 63 text

No content

Slide 64

Slide 64 text

Nevýhody? Nutnost pojmenovat všechny prvky

Slide 65

Slide 65 text

ITCSS

Slide 66

Slide 66 text

Co ITCSS řeší? Organizaci souborů Boj se specificitou

Slide 67

Slide 67 text

Settings

Slide 68

Slide 68 text

Tools

Slide 69

Slide 69 text

Generic

Slide 70

Slide 70 text

Elements

Slide 71

Slide 71 text

Objects

Slide 72

Slide 72 text

Components

Slide 73

Slide 73 text

Utilities

Slide 74

Slide 74 text

Co na to JavaScipt?

Slide 75

Slide 75 text

CSS Modules Styled components

Slide 76

Slide 76 text

Starší než CSS

Slide 77

Slide 77 text

Co se snaží CSS-in-JS řešit? Globální platnost Pojmenování třídami

Slide 78

Slide 78 text

CSS Modules Klasické CSS Transformace do JavaScriptu

Slide 79

Slide 79 text

Nevýhody? Závislost na JavaScriptu

Slide 80

Slide 80 text

Styled Components Klasické CSS