> a 1-second page slowdown could cost Amazon $1.6 billion in sales each year.
data:image/s3,"s3://crabby-images/c7dbb/c7dbb98f73997b3cc1861b87684e22e4fa7ee904" alt="Performance == UX"
Today I'm going to share 11 performance tips with you
## Agenda
- Front-end Performance 101
- Optimizing the critical path
- Animations
- Selectors
#1 Put styles at the top and scripts at the bottom
#2 Make fewer HTTP requests
#3 Maximize the parallelisation
#4 Use DNS prefetching
```html
<link rel="dns-prefetch" href="http://avenuecode.com/">
```
#5 Gzip and minify the resources
#6 Remove the ability of the user to zoom to eliminate the 300ms click delay(mobile)
Even better, eliminate the 300ms delay without accessibly using FastClick
data:image/s3,"s3://crabby-images/211a0/211a0d96363089d8c4f9cd0d6cb342d18b913de6" alt="Yslow"
[developer.yahoo.com/yslow](http://developer.yahoo.com/yslow)
data:image/s3,"s3://crabby-images/94d3f/94d3f122645ba3793b2e5c487e8d32c8975b8d63" alt="Page Speed"
[developers.google.com/speed/pagespeed](http://developers.google.com/speed/pagespeed)
data:image/s3,"s3://crabby-images/7589f/7589fc1ceef1c241659e1cbdb09dfaa0363a4113" alt="Browser Diet"
[browserdiet.com](http://browserdiet.com)
> “Critical path is the necessary journey between a user requesting your page and then actually seeing something” - [CSS Wizardry](http://www.csswizardry.com/)
Loading CSS blocks the page rendering, so...
#7 Serve CSS files from the same host (No DNS lookups).
#8 Consider using inline styles
4 things a browser can animate cheaply
- Position (transform: translate)
- Scale (transform: scale)
- Rotation (transform: rotate)
- Opacity
#10 Animate using transform (it may require translateZ or translate3d)
data:image/s3,"s3://crabby-images/92df5/92df503b21fad01bce9ad763c8a18a144f8440e0" alt="Animate.css"
[daneden.github.io/animate.css/](http://daneden.github.io/animate.css/)
data:image/s3,"s3://crabby-images/18983/18983192a15ae2c3dafe20e23616fefafdd0cd94" alt="Effeckt.css"
[h5bp.github.io/Effeckt.css/](http://h5bp.github.io/Effeckt.css/)
Key selector
```css
ul > li > * {
...
}
```
[TLDR;](http://csswizardry.com/2011/09/writing-efficient-css-selectors/) NO!
#11 Before worrying about CSS Selectors performance (micro improvements) do the basics
## Learn more
- [Front-end Performance Guide - CSS Wizardry](http://csswizardry.com/2013/01/front-end-performance-for-web-designers-and-front-end-developers/)
- [Browser Diet](http://browserdiet.com/en/)
- [CSS the critical path](http://www.phpied.com/css-and-the-critical-path/)
- [High Performance Animations](http://www.html5rocks.com/en/tutorials/speed/high-performance-animations/)
- [Writting Efficient CSS Selectors](http://csswizardry.com/2011/09/writing-efficient-css-selectors/)
- [Avoiding the 300ms click delay](http://timkadlec.com/2013/11/Avoiding-the-300ms-click-delay-accessibly/)