Refactoring CSS
FOR PERFORMANCES
Mattia Tommasone
@raibaz
RED
GREEN
REFACTOR
"the process of changing a software system in such a way that it does not alter the external behavior of the code yet improves its internal structure"
"What is technical debt?" Technical debt is hard to explain, but a picture is worth a thousand words. #programming #softwaredevelopment
https://twitter.com/Jedd_Ahyoung/status/826551935822077952
Quando fare refactoring
- (Quasi) sempre
"If it ain't broke, don't fix it"- Boy scout rule
- Code smells
- Non alla prima scrittura
- Per allineare del codice legacy a nuovi standard (pattern, librerie, etc)
MA IN CSS...
Code smell #1: undoing
h2 {
font-size: 2em;
margin-bottom: 0.5em;
padding-bottom: 0.5em;
border-bottom: 1px solid #ccc;
}
.no-border {
padding-bottom: 0;
border-bottom: none;
}
h2 {
font-size: 2em;
margin-bottom: 0.5em;
}
.headline {
padding-bottom: 0.5em;
border-bottom: 1px solid #ccc;
}
Code smell #2:
magic numbers
height: 37px;
line-height: 1.2em;
width: .7345rem;
border-top: .1875em solid purple;
Code smell #3:
Selettori troppo (o troppo poco) specifici
ul.nav li.active a {}
.content ul.features a.button {} //Do you know BEM?
header {}
h2 {}
Code smell #4: Id
- Uno solo per pagina
- Sono più specifici di qualunque combinazione possibile di classi
- Non c'è veramente un motivo per usarli
- Ci sono dozzine di motivi per NON usarli
Code smell #5: Lo stesso selettore finale più volte
.btn {}
.header .btn,
.header .btn:hover {}
.sidebar .btn {}
.modal .btn {}
.page aside .btn {}
nav .btn {}
ISOLATE
Trick #1
all: initial;
Sad Trombone :(
http://caniuse.com/#feat=css-all
!!!!!
Trick #2
shame.(s)css
- Raggruppa in un unico posto tutto (see, magari) il codice "brutto"
- Anticipa la sedimentazione delle code smells
- Funge da TODO list del debito tecnico
- Tiene traccia del perchè sono stati fatti degli hack
Credits: https://csswizardry.com/2013/04/shame-css/
-
git blame shame.scss
- Non serve a fare finger pointing
- Non è una scusa per scrivere il peggior codice del mondo
- Il codice al suo interno dovrebbe avere vita breve
TRICK #3
TRICK #4
- Quick wins
- Il primo impatto potrebbe essere devastante
- Si può scegliere quanto peso dar loro
mantenibilità, leggibilità, chiarezza
...sì ok, ma le performances?
regole generali
- Non tutti i selettori sono uguali
- Usare la GPU è una buona idea
- Usare le animazioni lo è meno
-
Time to first render?
-
Time to first meaningful paint?
-
TIME TO INTERACTIVE?
-
FPS?
Refactoring CSS for performances
By Mattia Tommasone
Refactoring CSS for performances
- 346