Sinking in the sea of modern JavaScript
Interested in learning JavaScript? Get my free ebook at jshandbook.com
Until a few months ago I could not even look at JavaScript without having a feeling of anxiety. I was 100% under the so-called JavaScript Fatigue and I could not get out of it. This lasted years.
Today, I love JavaScript and its ecosystem.
How did this happen?
I’ve been using JavaScript in some form or another since the nineties, and I have some books on my shelf that looks very funny today, full of document.write
statements.
JavaScript has hugely changed in the last few years. At first, I could not pick up all the things that were going on. I could not accept so many changes all at once. JavaScript was changing but I was resistant. I took so much to learn it properly, and now it’s changing under my feet.
I found really spot on a comment made on the popular Modern JavaScript Explained For Dinosaurs post, when it argued that “learning modern JavaScript was tough if you haven’t been there since the beginning”:
I would argue being there since the beginning (yes, I’m *that* old) makes it even tougher — Tim Tate
I dived into JavaScript and Node.js seriously in 2012, and I had never experienced a language change so incredibly huge as ES6. The previous big change happened in 2009 with ES5. ES6 literally changed everything. It was such a huge revamp of JavaScript that every day you had so many things that could get into that spec but you didn’t really know if they made it, and you had to catch up as everyone on Twitter was talking about those things that maybe were the next big thing.
var
was left in the dust.
function
never exist any more.
Prototype-based inheritance, which took a long time to learn properly, is gone, hidden under the 🌈 carpet of classes.
This was just the surface.
One big shift that was happening was building.
We went from a very simple thing, including our JavaScript with script
tags, to having build steps that compile our language to some incomprehensible huge file. At first I resisted strenuously, I got up in my tower fully armed with cannons to fight the build army.
But when the Babel forces came along, I initially fought even harder but in the end I raised the white flag, and I joined the enemy.
I realized Babel is not some fancy library that introduces future, edge features, and when those land in the browser we’ll forget Babel. No, Babel is here to stay, for the foreseeable future.
When ES2017 will fully land in the browser, Babel will allow for ES2018, ES2019 and so on. There’s no escape. Embrace the future, Babel is your friend.
The tooling is one of the hardest part of JavaScript nowadays. Yes, you can learn all about Webpack but when you start out, ignore everything and use ready-made solutions like [create-react-app](https://github.com/facebook/create-react-app)
, the React Boilerplate that hide the tiny details for you and let you focus on the code.
Don’t start by setting up an environment, learn by using Glitch: there’s no simplest thing to start diving into modern JavaScript.
ES6 was so big that the ECMAScript committee decided to do smaller releases next time. This is why ES6 is also called ES2015, and was the first release with the year— we’ll have a yearly release from now on. It’s easier to catch up, will have less changes as the time to add them is limited, and it’s predictable (surrend, there will be change).
If you’re like me, you might follow a lot of people on Twitter that are always on the edge. Maybe some thought leaders that dictate what’s the next big thing. They say to use X, everyone else uses X.
Maybe they like to show their snippets using the latest APIs which are not even close to be standard, but can be used with a flag in the browser.
They might have a good reason. You do not. Don’t fall in the trap of the new shiny toys, focus on your work.
There is a joke floating around that says “whatever JavaScript framework flavor of the month” or “there’s a new library every week”. That’s true, there is a gazillion people working on JavaScript and this is great, it brings innovation and evolution, the kind JavaScript experienced in the last few years, which were huge for the language ecosystem.
But the thing to note is that the big things do not change much frequently.
React is 5 years old.
Vue is 4 years old
4 years is a very long time in tech. Those are stable technologies. Learn it now, they are here to stay for long, too — not going away.
You have plenty of time to become an expert in any of those frameworks, they are not going to go away any time soon.
That said, anything has a lifecycle.
A few years ago jQuery was used everywhere, now rarely new projects start with it.
In 2013 Backbone.js was huge. Now it disappeared from the map.
CoffeeScript, removed from the face of earth.
Ember.js, Angular.js and Meteor rocked and stayed at the top of their popularity for a few years, now the most talked ones seem to be React, Vue and Angular (which is different from Angular.js).
Each cycle for those major frameworks usually lasts quite a few years. I still have lots of Ember.js applications running just fine, there is no need to update them if they do their job, and I don’t plan to touch them.
Tech evolves and matures, then it gets used rather than talked about.
Some people have a thick skin, but if you read around enough, you fill find out those that despise technology that once everyone used — since they know better, they want to inform you that you are wrong 😆
Having used PHP for a long time, I got used to this, it’s normal to have people criticizing something popular. Even Go, which is amazing for its simplicity and sometimes criticized for that. You will always find someone that throws shit at something.
As an example, I have to cite this tweet by Pieter Levels, which built a huge independent business with a single PHP file. And see the comments 😉
But as a beginner you might find out someone that says you’ve chosen an old tech, that no one uses it any more, that you should use React instead.
Ignore them, move them out of your mind.
Remember: if it works for you, it’s the right stack.
If it works for you, it’s the right stack.
Most of the times tech is built from giant companies with needs completely, radically different than yours, or the ones of your small team. Go with what you know and make a difference even without using leading edge technology.
Now, probably you don’t need jQuery. But not in place of a framework — plain JavaScript is super fine.
The other part of the spectrum is over-engineering. Don’t use a tech just to feel smarter. Know it better. And learn when to use a framework or library helps you.
While it might sound from reading your Twitter feed, no one knows everything. There’s no way one can learn all the stuff that’s going on in frontend development. This is a lifetime school. There’s absolutely now way to graduate.
It’s not by chance that React and Vue have an amazing documentation.
It’s a key part of their success.
Last year the ECMAScript language introduced await/async and now that feature of the language is used a lot. Promise-based code looks simply bad, you feel the urge to rewrite everything.
Don’t do it, and instead use new features for new code you write.
The same will happen this year, with ES2018. Everyone will talk about them for a while, then we’ll get back to work and we’ll start talking about the ES2019 features.
Embrace the change. It’s much better than betting on a tech that then stalls and fades into being irrelevant in a few years: JavaScript is here to stay!
Developing on the Web Platform requires a commitment to learn something new often, even just to find out what’s possible.
Sometimes learning in 20% of the time the 80% of the things you will need is enough, without diving too much into the edge cases.
JavaScript is still very young compared to other languages, it’s hugely popular and it was able to dramatically change in the last few years. It attracts lots of new talented developers every day, and it’s fascinating thinking about the JavaScript we’ll write in 10 or 20 years from now.
Interested in learning JavaScript? Get my free ebook at jshandbook.com