It was the first day of 2019 and I was not where I wanted to be. I felt at my peak when learning something new. The new year started with a project idea, and the winter ended with an unmotivated, unfinished project.
I missed the college coding grind--learning new things and bringing ideas to life. A skill I've always wanted to master was CSS. I want to leverage it and create compelling user experiences for people to enjoy. My background in Python, Java, and C++ gave me a solid computer science foundation. Now it was time to modernize my skills and make my work functional and visually appealing.
One day I opened CodePen, felt waves of inspiration, and got right to work. I studied HTML and CSS using the MDN Web Docs, W3Schools and CSS Tricks.
Around this time I was also teaching myself vector drawing and animation using Adobe Illustrator and After Effects (until my free trial ran out...). When I found this pure CSS BB-8 animation on CodePen, I was captivated. I had to learn how to do that.
And so it began.
I challenged myself to spend 20 days coding CSS animations before the end of the year. The final day was when I got the most ambitious, and the most creative, so I spent a total of 25 days!
You can view my 25 Days of CSS journey on CodePen.
The Bare Minimum
Everyone starts small. For the first 10 days of the challenge, I used the following to brush up on the basics. These served as the foundation for my frontend skills:
- HTML: Hypertext Markup Language; creates the content of a webpage.
- CSS: Cascading Style Sheets; describes the style of a webpage.
Everyone also gets lazy and curious (by everyone I mean me). Once I was comfortable with the bare minimum, I explored tools that would improve the development process:
- Sass: Style sheet language that provides variables, functions, mixins, and more to streamline CSS.
- Pug: A template engine for a more clean, whitespace sensitive syntax for HTML--great for speeding up development.
- Visual Studio Code: A cross platform source-code editor. Used to practice setting up my Pug and Sass developer environment.
I wanted to take time and care to learn and understand CSS properties and its uses. Breaking down my creative process in this way enabled me to make something fun and learn something new.
1. Have an Idea
I'd browse Dribble, CodePen, and r/MotionDesign for inspiration.
I can be overly ambitious when learning something new, so finding inspiration on these sites helped me scope my animations while realizing CSS's capabilities.
Then I wrote down every possible idea I had with no limits. Most of my ideas came from things I enjoy like video games, sci-fi, kawaii culture, the list goes on…This would help me persevere through challenges and motivate me to keep working on it.
2. Sketch a Blueprint
I'd start off with a rough sketch of the animation. This is where I planned my HTML elements, and the animation directions for specific elements.
3. Find Examples
The beauty of coding is that you can learn from existing implementations and repurpose them for your own.
Why reinvent the wheel? Improve it with new ideas.
I inspected animation code that seemed similar to what I was trying to accomplish, and combined it with what I learned to form an elegant solution. CodePen and the Chrome developer tools were a big help here.
Equipped with ideas, blueprints, examples, and my Bulbasaur plushie, I brought my CSS ideas to life. I've had roadblocks, I've been personally victimized by typos, and I wasn't always happy with my pace. Thankfully, online research and rubber ducking helped me learn from my mistakes and progress faster and faster after each project.
Days 1–8: Start Small & Recreate Examples with a Twist
The first 9 days focused on understanding shaping, positioning, keyframes, and transitions. I grabbed designs, animations, and pens I really liked, and tried to recreate them from memory.
Part way through my challenge I felt insecure. I wondered whether or not there was any merit or value to learning CSS this way.
Am I wasting my time? Is this even useful for web development?
Well, let's find out.
I put my new skills to the test by designing and coding the frontend for a make up e-commerce site using plain old HTML and CSS:
Here I used the traditional column layout with the clearfix method, studied the tradeoffs between traditional columns, flex boxes, and CSS grids after using flex boxes in my animations, applied media queries, and debugged elements through Chrome's developer tools.
Then, I worked on a fun redesign of MAC Makeup's landing page inspired by Julie Park's FitBit landing page. I applied my knowledge of CSS positioning, transitions, borders, box shadows, render orders, fonts, and clips.
Animating armed me with the ins and outs of numerous CSS properties like backgrounds, transforms, borders, positions, the list goes on. Animating reinforced newly acquired skills, and thus exercised them by building static web pages.
Whether you're a frontend developer, CSS animator or hobbyist, we're all using the same language -- the skills and concepts learned are transferrable by default.
Liquid error: internal
Days 9–25: Climb the Curve & Code from the Heart
My later projects were based on original ideas once I got more comfortable with CSS. I've always wanted to make an animated avatar, and cute animations inspired by my everyday life. Some of my work was also inspired by my favorite Nintendo video games like Super Mario World 2: Yoshi's Island and Pokémon.
Day 10 is one of my personal favorites. I made this once I realized how much I love coding. Before this challenge I've had several low points, wallowed in doubt, and grew skeptical of my path as I felt my skills and projects weren’t as competitive and impactful as my peers yet.
Thankfully I remembered why I'm doing this--to learn and to create engaging experiences. With that in mind I pursued this challenge with hard work, determination, and self improvement, and in turn it restored my love for coding.
Day 12 was spent styling my first full stack project for my coding bootcamp which was a single paged Tic Tac Toe game. Since our whole cohort was assigned the same game, I gave my version an animated personality:
I resumed my personal animations for days 13 - 25:
This one is another favorite. Days 17-18 was inspired by this gorgeous scene from my favorite Pokémon episode Bulbasaur and the Mysterious Garden.
This last pen was an interesting one to work on. I revisited Pokémon X for the Nintendo 3DS and opened up Pokemon Amie. This feature lets players pet and feed their their Pokemon using the 3DS touch screen. It's fun and therapeutic on a rough day, so I was compelled to code a desktop version for myself and others to use.
I'm grateful for this journey. I learned key CSS concepts like keyframes, transitions, transformations, blend modes, clipping, masking, media queries, pseudo elements, flex boxes, and much, much more.
Additionally, I grew more confident in my coding and problem solving abilities. I've picked myself back up by completing projects from start to finish, managing my scope, asking questions, and maintaining a growth mindset.
I'm encouraged by this challenge. I'm excited to learn more and tackle more frontend projects in the future.
Latest comments (87)
I know I am not the first person to say it but you are on another level. If you could do this in 25 days, I can't imagine what you can do in a year. Salute to your work ethics and determination.
Hi Tee! Thank you so much for sharing your experience. I am now ready to begin my path in Css Animations. I think I was waiting for a challenge like this one.
This is sooo good and inspirational to read. Keep it up buddy..
I don't usually comment here, but wow! Pokemon animations are super cool. Great work!
I cannot describe how amazing this is. I've been wanting to level up my CSS skills but never felt confident enough to do this much animation. Maybe this can give me some motivation. Thanks for sharing!
I personally think that this is one of the best ways to learn new things - build fun and interesting for you projects. You can devote a small project like these to one thing or a concept and finish it in a couple of evenings or so.
Then, when you gain more skills in this area, you can combine them into something much more substantial.
The most fun part here is that there are no rules! You can do anything you want. You can let your imagination roam free and just code whatever you like, however you like.
Nobody is going to stand behind your shoulder and complain about missing requirements or strict deadlines.
Thanks for sharing this.
Well said. This is exactly how I felt while pursuing this, and it really paid off. Since finishing my challenge I noticed that I’ve been much more mindful about my CSS usage since this helped me understand properties at a deeper level. Now I work as a frontend engineer and and I’ve been able to pick up my companies code axe and conventions very easily. I’m also helping rewrite our CSS documentation too. Passion projects really do pay off.
so good , very nice , It made me think again.
Very inspiring work. I'd love to try something like this in 2020. Thank you for posting!
I always wonder if some day we can have a (great) software like Ae to export css/svg animations. We need explore this potential on artists.
I love the creativity in how you created the scenes with divs. 25 days very well spent. Well done!
Wow! These look really cool.
@acupoftee these are amazing! 3 questions:
I loved and enjoyed your post, amazing! (and cute!)