We developers talk a lot about HTML5, CSS3, EcmaScript 6 news that we almost forget to talk about other things that are also very important, but aren't as novelty just like web performance.
After a huge effort, we finally launched a community-driven performance guide called browserdiet.com and today I'm here to share my experience leading this awesome project.
2012 was a very different year for me, I spent 1/3 of my time traveling to give talks and I found a lot of bad internet connections in hotels and airports. It made me very angry. And of course I always cursed the hotel/airport, until realize that's actually our fault.
We developers are selfish. We spend all day at the office with a high speed connection and forget that there are other people in the world experiencing different speeds.
I started to study more about Web Performance Optimization (WPO) and came across the following scenario. In english, excellent references like High Performance Websites and Even Faster Web Sites books, both by Steve Souders. Besides Yahoo! and Google's online guides. In portuguese, a dozen of lost blogposts.
So I thought: "What if I created the ultimate community-driven performance guide?" But it didn't make sense to do it alone, so I started to talk with some friends.
One thing was very clear to me, I wanted to do a fun project.
First, I conviced a designer called Briza Bueno (Americanas.com) to help me. She developed an identity much more funny than those boring guides that exist today. All based in Scott Johnson's illustrations, whom I asked permission to use images.
Then it came time to develop the structure of this website, Iraê Lambert (Yahoo!) helped me on that part writing a static generator in Python. But I didn't master that code and the barriers I encountered for not knowing what was manipulating started to keep me away from the project, while other ideas were emerging.
Result: the project was stopped for one year until I decided to rewrite everything using another static generator in Node.JS called DocPad. Like any other open source project, if you want to do something with the collaboration of people you'll need to eliminate as many barriers as possible. So, inspired by HTML5 Please, I decided that all tips would be written in the simplest format in the world, Markdown.
My eternal dilemma between Portuguese and English also persisted in this project. I even bought this small domain comoperderpesonobrowser.com.br, but it clearly wouldn't work for an english content too. That's why I opted for something shorter and universal.
After much improvement I decided to invite other guys to review, like Marcel Duran (Twitter), Mike Taylor (Opera), Renato Mangini (Google) and Sérgio Lopes (Caelum). Everyone was excited and insanely contributed, including questions related to the code of the website were extremely debated like CSS Sprites vs Lazy Load.
I was planning to launch this project at least in April. But when I saw that the first contributors (Briza, Davidson, Giovanni and Jaydson) would be present at Rio.JS I changed my presentation title and started running against time.
Fortunately everything worked out and we launched the project!
The final result you can see at: browserdiet.com.
Source code, as always, is available at Github.
PS: My slides are also online for those who weren't there.
I'm very excited to see how the community will receive and benefit from these great tips that we prepared.
So, let's make the web faster?
love this new project: browserdiet.com— Stoyan Stefanov (@stoyanstefanov) March 11, 2013
Stoyan Stefanov, Engineer - Facebook
How to lose weight in the browser — the definitive front-end performance guide: browserdiet.com— Mathias Bynens (@mathias) March 11, 2013
Mathias Bynens, Web Developer - Freelance
Ilya Grigorik, Developer Advocate - Google
Some of Brazil's brightest front-end devs created and just launched browserdiet.com. Check it out!— Mike Taylor (@miketaylr) March 11, 2013
Mike Taylor, Web Opener - Opera
Stay up to date
My email list is the best way to follow all the work I'm doing. Sign up below.