I have a confession to make. I don’t really know JavaScript. Some of you, who know my plugins, like WP SmartCrop, Blockade, and WP jSlabify, might say “But that’s some pretty heavy JavaScript!”, but that is where things get complicated. You see, I know math, I know programming, and I know the DOM, inside and out. By knowing those things really well, and treating JavaScript like any other language, I can make pretty cool things! But that’s not the same as knowing JavaScript anymore.
Over the past few years, JavaScript has evolved very quickly, and in ways that don’t really seem familiar to other languages. JS has always been a strange language, with quirks like hoisting, loose typing, and forced double precision, as well as varying browser implementations. But, as it has grown to dominate the web, new versions, tools, and tropes have been introduced that are very unfamiliar to many programmers.
The traditional, fractured JS landscape is now supplanted by ECMA Script, which provides a standard language, with many new features and syntactic sugars, but also requires a compilation step, to be compatible with all browsers. Frameworks such as React or Vue are now standard fare for managing application states and views, and new templating formats like JSX have become commonplace. Hell, even styling is often handled directly with JavaScript now.
Until recently, WordPress remained relatively sheltered from all of these changes, being mostly built with jQuery and traditional JS, with the only exception being the Media Library, which most developers treat like a black box (for good reason). However, That all changes this year.
This year, WordPress will release the Gutenberg editor, as a first step towards eventually retooling the dashboard into a modern JavaScript-based application. As such, ES6, Babel, React, Webpack, and all the other tropes of new JavaScript development will become crucial for developing rich admin experiences in WordPress. And, as a result, this is the year I’ll be finally learning this new JavaScript.
To start off, I asked my JS Dev friends for a few book suggestions, which I’ve included below. I’ll be reading each of these, this year, starting off with the essential JavaScript: The Good Parts, which is often credited with kicking new life into JavaScript’s corpse, and the open source You Don’t Know JS series of books. Later, I’ll dive deeper into React, Vue, and node, using the trusted O’reilly series. Finally, I’ll do some structured reading on the WordPress REST API, to tie it all back to our favorite CMS.
If you want to learn along with me, here are links to the books I’m currently planning to attack.
[amazon_link asins=’0596517742,B01AY9P0P6,1484226224,B071HB1526,1491949309,B01C2XX8WY’ template=’ProductCarousel’ store=’gschoppe-20′ marketplace=’US’ link_id=’cc55294e-f8e2-11e7-b438-4348033ba2bc’]
If you have suggestions for others, or against any of these, feel free to leave them in the comments, and I will take the time to review your suggestions.
Josh Levinson says:
Good luck! I highly recommend checking out egghead if you’re not already familiar with that resource.
gschoppe says:
I took a very brief look.. the courses seem to be a bit of a mixed bag, but this one seems promising: https://egghead.io/lessons/react-introduction-to-the-beginner-s-guide-to-reactjs
Collins Agbonghama says:
Also checkout ES6 for humans, Exploring Javascript and JavaScript web application. They are also great books on JavaScript.
gschoppe says:
just added ES6 for humans to my list! I’ll look through the others soon 🙂
Stefanos says:
I would like to recommend two of my favorite books by the incredible Nicholas Zakas:
The Principles of Object-Oriented JavaScript
and
Understanding ECMAScript 6: The Definitive Guide for JavaScript Developers.
Both books are eye opener!
Basically anything by Zakas is a must for front-end developers.