When I started working in information technology professionally in 1989, things were pretty easy in terms of choosing a direction to head into. At least in my area (South Florida), you went into one of the following areas:
ColdFusion was my technology of choice and it too lasted me nearly ten years.
I took the software development route and for a very long time, it was easy to choose a programming language that you could base your career on. In my case, I started with Clipper (a dBase-based compiler) and eventually branched into client-server development using PowerBuilder, the latter being my goto tool for almost five years.
And even when I got into web development, tools and technologies were still easy to choose, primarily because the web was still so young and simple post-back, server-side page refresh style development. ColdFusion was my technology of choice and it too lasted me nearly ten years. And most recently, jQuery and JavaScript have been my focus since 2008.
There's a reason I'm telling you all of this.
I've been very fortunate to have chosen technologies that have had great longevity but of recent, I've noticed a dramatic change in the industry. The maturation of web development has led to an explosion of new tools that aim to help manage the complex process of building today's sophisticated websites and apps. This is actually a very good thing since for a long time, web development was like the wild west. The formalization of patterns, processes and best practices is certainly a positive thing and will invariably help to build substantially more stable systems.
And a lot of this explosion has been driven by the ease of access to sophisticated programming languages and tools, many offered for free via the open source community. This has enabled developers to rethink the way things should be built and empowered them to build amazing tooling.
This empowerment, though, can be a double-edged sword for the developer community as it feels like we're on a hamster wheel with no brakes that allow us to stop and take things in. It's a bit of a perpetual learning cycle where in many cases, not staying on top of the latest development trends can put you incredibly behind in terms of current development practices. I know I've felt it more than once and in talking with my peers, it seems to be a pervasive feeling.
I think it's fair to say that software developers have one of the most complex jobs in the world.
You'll hear constantly from others that our field is one of constant learning and that is so true. Developers are rockstars nowadays and it's because we work on cutting edge stuff that makes a tangible impact on large communities of people. And those communities are demanding more information via easier user experiences across multiple form factors. I think it's fair to say that software developers have one of the most complex jobs in the world. So constantly learning isn't a choice anymore; it's a requirement.
Which is why I was mentioning my career path to-date. I think it mimics that of a lot of my peers, where we could comfortably depend on knowing some "thing" for "x" number of years before we had to begin to retrain ourselves. If you're in the web development world, that's no longer the case and in my opinion, a career limiting move. I'm not saying that you need to go off and learn every new library that comes out. Honestly, I think many of the libs and tools being pushed out:
But there is a clear rationale for staying on top of emerging technologies especially when you see your peers chatting about them. And to be clear, I don't define peers narrowly as those I work with. I look closely at people on Twitter, Facebook, Google+, blogs and forums to gauge where their thinking is at. If you're not doing the same, you're doing yourself and your career a disservice.
As you get older (yes I'm touching on age), for most, "time" becomes the biggest limiting factor to staying current. I can attest to this as at age 45 with a ton of family commitments, I have to be extremely regimented in order to dedicate the necessary learning "time" while ensuring I dedicate "time" to my family (which is my number one priority). And I'm confident I'm not alone in this conundrum. I think back to when I was in my 20s and used to write for print magazines (you guys remember those right?) and my colleagues would ask, "How do you have time to do that?". Well, it has come full circle and I find myself asking my 20-something developer friends the same thing.
The thing I've learned is that I can't compare myself to a 20-something because our priorities in most cases are different. A young buck will invariably have more time to focus on the newest stuff allowing him or her to tinker away and even build that next great tool. And that is awesome and I remember those days myself!
As you progress in your career though, it's important not to be lulled into complacency and develop a plan that will allow you to stay up-to-date by being selective of not only the technologies you choose but also the goals you plan on achieving.
As you look at the technologies that are currently available, it's easy to become overwhelmed at where to start, much less what to choose. I empathize with you and you are certainly not alone. Part of the problem is that as developers, we're naturally curious about new technology. I like to call it the "moth to a flame" syndrome:
The list could go on and on. What I'm trying to get at is that at times, we suffer from attention deficit and try to rationalize it by thinking it will immediately solve a non-existent or future problem for us. In essence, we're technology hoarders doing a "just in case". In reality, it's important to sit back and determine what you're trying to accomplish and how the current suite of tools solve your problems based on where you want to head to.
Part of the problem is that as developers, we’re naturally curious about new technology.
For example, I've heard so many developers say that they want to learn iOS only to find that they have no real plans for building an iOS app. If you have the time to do that for fun, more power to you but if you don't, that's time that should be spent learning things that are actually important.
For example, if you're a front-end web developer and that's what you plan on being for some time, I'm of the thinking that ensuring you're up-to-speed on things such as AMD, ES6, Sass and Yeoman is far more important than diving into IPTables, ActiveRecord, WebView or Amazon EC2. Before everyone loses their minds because of what I just said, let's be clear, if you can manage to learn all of these things (for example, a full-stack developer), more power to you because it will make you more valuable.
What I'm trying to convey is that instead of allowing yourself to become overwhelmed with the thought of learning "the full stack", narrow down the scope into easier to manage goals. Determine where your career focus is, pinpoint a handful of key technologies you should be up-to-speed on, and focus on those in order for you to stay relevant within your career focus.
The front-end developer tract, for example, is involved enough and staying current will keep you busy for a long time. Lou Lazaris wrote a post back in 2011 titled "Skills for Front-end Developers" and in many cases he's spot on. If you look at his list, he's specifically targeted front-end technologies that are important to that role. It reinforces my thinking that it's better to narrow down the scope of what you're learning into manageable chunks within the role you're in. But it's also important to filter down lists like these even further. Do I think that CoffeeScript is critical to my success as a front-end dev? Absolutely not, which is why I've purposely not dedicated time to it.
Again, I'm not advocating not learning as much as you can. Despite me clearly being on the front-end side of things, I'm currently working on learning Ruby and Rails because I'd like to learn a new server-side stack to round out my skills. For me, it means sacrificing learning how to use something like Yeoman but I've taken the time to determine the value proposition of going down this route and I think it's worthwhile for me.
Learning comes in different styles. I learn best by:
Others prefer to simply dive into something and learn by the school of hard knocks. Whichever way you learn, having good resources available is a critical part of the equation.
More and more, I've been leaning towards online courses because they've matured to a point where in many cases they're comparable in quality to their onsite brethren. They also afford the flexibility of allowing you to do things on your own schedule (almost always) and to focus on the technologies that are important to you.
In my case, I recently signed up for One Month Rails which offered me the following:
Regardless of what learning options are available, if you don't set aside some dedicated learning time, it's all irrelevant.
I see this as a jumpstart opportunity that will be complemented by sites like Nettuts+ and Tuts+ Premium as well as books and my community contacts. But ultimately, the flexibility and pace of the course is what I feel will allow me to learn something new in a timely manner. Cost is certainly a factor which you need to weigh versus the anticipated learning benefit and resulting updated skill.
The fact that there are so many online learning options available (many of them free) makes it substantially easier to keep your skill-set current, especially if you're methodical about what you want to learn (for example, don't be a moth).
But you need to carve out the time to learn. Regardless of what learning options are available, if you don't set aside some dedicated learning time, it's all irrelevant. I've personally found that spending one to two hours, two to three times a week immediately after work seems to work well because my mind is still in developer mode. I recently chatted with a friend who finds it better to wake up very early (6am) and focus on learning during the first few hours of the morning before starting work. That way, he's fresh and focused, free of distractions or concerns about his job.
My good friend and badass developer Joe McCann offered this great feedback:
“The one bit of knowledge I'll add is that the number one thing I learned studying philosophy in college was not what I was learning, but how I in fact learn things. Truly understanding how one learns, understands, etc. is key to learning a new skill or enhancing current ones.
If someone learns by reading a book or writing down notecards or hearing it via lectures, all of these are available to use now online. It's a matter of understanding how you learn and then going and seeking the proper medium to do so.“
Well said.
It goes without saying that I think Nettuts+ and the various Envato properties offer some of the best online learning options around. In addition, here are a couple of learning sites I've used and recommend:
If you want something a little more structured and hardcore, a new trend are onsite bootcamps where you will invest a considerable amount of time learning how to use the newest technologies. Just note that many of these require you to move to where the bootcamp is being held and commit full-time to it for a number of weeks. Also, these courses are pricey running into the thousands of dollars in exchange for the more personal learning experience. I've personally participated in the Bloc.io bootcamp but didn't require moving. While I wasn't able to finish it due to time constraints, I would recommend it. Here are some of the bootcamps that have received a lot of positive press:
The site BootCamper has been aggregating a list of the various bootcamps that are available and providing information about them in a searchable fashion.
The main thing is to keep learning and do it at a manageable pace and in a thoughtful manner.
I've been wanting to write something like this for awhile. It's a bit self-serving since it helped me jot down feelings I've had about being overwhelmed with the hamster wheel of learning. Over time, I've been looking at ways to ensure I'm staying on top of things while not burning myself out and I've come to realize that it's impossible to stay on top of everything, even in my own niche. There's just too many devs building too many cools things and not enough "time".
So I've resolved to focus on things that are timely and relevant but may not be bleeding edge and the newest cool toy. I find this to be a much more manageable way of learning for me. And I also think it's important to revisit the tried and true stuff that may not be the latest model car but may have some great surprises for you under the hood. I look back to Jeff Atwood's great post "Why Ruby?" where he discusses his choice for using Ruby to build Discourse and specifically touches on Ruby's maturity and lack of coolness.
The main thing is to keep learning and to do it at a manageable pace and in a thoughtful manner. Really give thought to where you're heading in your career, outline the key things you should be good at within that scope and work towards developing a plan to tackle staying current. There are plenty of flames out there and you don't need to flap your wings to every one of them.
I'd love to learn more from you guys how you stay up-to-date so please be sure to offer your suggestions in the comments.
The Best Small Business Web Designs by DesignRush
/Create Modern Vue Apps Using Create-Vue and Vite
/Pros and Cons of Using WordPress
/How to Fix the “There Has Been a Critical Error in Your Website” Error in WordPress
/How To Fix The “There Has Been A Critical Error in Your Website” Error in WordPress
/How to Create a Privacy Policy Page in WordPress
/How Long Does It Take to Learn JavaScript?
/The Best Way to Deep Copy an Object in JavaScript
/Adding and Removing Elements From Arrays in JavaScript
/Create a JavaScript AJAX Post Request: With and Without jQuery
/5 Real-Life Uses for the JavaScript reduce() Method
/How to Enable or Disable a Button With JavaScript: jQuery vs. Vanilla
/How to Enable or Disable a Button With JavaScript: jQuery vs Vanilla
/Confirm Yes or No With JavaScript
/How to Change the URL in JavaScript: Redirecting
/15+ Best WordPress Twitter Widgets
/27 Best Tab and Accordion Widget Plugins for WordPress (Free & Premium)
/21 Best Tab and Accordion Widget Plugins for WordPress (Free & Premium)
/30 HTML Best Practices for Beginners
/31 Best WordPress Calendar Plugins and Widgets (With 5 Free Plugins)
/25 Ridiculously Impressive HTML5 Canvas Experiments
/How to Implement Email Verification for New Members
/How to Create a Simple Web-Based Chat Application
/30 Popular WordPress User Interface Elements
/Top 18 Best Practices for Writing Super Readable Code
/Best Affiliate WooCommerce Plugins Compared
/18 Best WordPress Star Rating Plugins
/10+ Best WordPress Twitter Widgets
/20+ Best WordPress Booking and Reservation Plugins
/Working With Tables in React: Part Two
/Best CSS Animations and Effects on CodeCanyon
/30 CSS Best Practices for Beginners
/How to Create a Custom WordPress Plugin From Scratch
/10 Best Responsive HTML5 Sliders for Images and Text… and 3 Free Options
/16 Best Tab and Accordion Widget Plugins for WordPress
/18 Best WordPress Membership Plugins and 5 Free Plugins
/25 Best WooCommerce Plugins for Products, Pricing, Payments and More
/10 Best WordPress Twitter Widgets
1 /12 Best Contact Form PHP Scripts for 2020
/20 Popular WordPress User Interface Elements
/10 Best WordPress Star Rating Plugins
/12 Best CSS Animations on CodeCanyon
/12 Best WordPress Booking and Reservation Plugins
/12 Elegant CSS Pricing Tables for Your Latest Web Project
/24 Best WordPress Form Plugins for 2020
/14 Best PHP Event Calendar and Booking Scripts
/Create a Blog for Each Category or Department in Your WooCommerce Store
/8 Best WordPress Booking and Reservation Plugins
/Best Exit Popups for WordPress Compared
/Best Exit Popups for WordPress Compared
/11 Best Tab & Accordion WordPress Widgets & Plugins
/12 Best Tab & Accordion WordPress Widgets & Plugins
1 /New Course: Practical React Fundamentals
/Preview Our New Course on Angular Material
/Build Your Own CAPTCHA and Contact Form in PHP
/Object-Oriented PHP With Classes and Objects
/Best Practices for ARIA Implementation
/Accessible Apps: Barriers to Access and Getting Started With Accessibility
/Dramatically Speed Up Your React Front-End App Using Lazy Loading
/15 Best Modern JavaScript Admin Templates for React, Angular, and Vue.js
/15 Best Modern JavaScript Admin Templates for React, Angular and Vue.js
/19 Best JavaScript Admin Templates for React, Angular, and Vue.js
/New Course: Build an App With JavaScript and the MEAN Stack
/Hands-on With ARIA: Accessibility Recipes for Web Apps
/10 Best WordPress Facebook Widgets
13 /Hands-on With ARIA: Accessibility for eCommerce
/New eBooks Available for Subscribers
/Hands-on With ARIA: Homepage Elements and Standard Navigation
/Site Accessibility: Getting Started With ARIA
/How Secure Are Your JavaScript Open-Source Dependencies?
/New Course: Secure Your WordPress Site With SSL
/Testing Components in React Using Jest and Enzyme
/Testing Components in React Using Jest: The Basics
/15 Best PHP Event Calendar and Booking Scripts
/Create Interactive Gradient Animations Using Granim.js
/How to Build Complex, Large-Scale Vue.js Apps With Vuex
1 /Examples of Dependency Injection in PHP With Symfony Components
/Set Up Routing in PHP Applications Using the Symfony Routing Component
1 /A Beginner’s Guide to Regular Expressions in JavaScript
/Introduction to Popmotion: Custom Animation Scrubber
/Introduction to Popmotion: Pointers and Physics
/New Course: Connect to a Database With Laravel’s Eloquent ORM
/How to Create a Custom Settings Panel in WooCommerce
/Building the DOM faster: speculative parsing, async, defer and preload
1 /20 Useful PHP Scripts Available on CodeCanyon
3 /How to Find and Fix Poor Page Load Times With Raygun
/Introduction to the Stimulus Framework
/Single-Page React Applications With the React-Router and React-Transition-Group Modules
12 Best Contact Form PHP Scripts
1 /Getting Started With the Mojs Animation Library: The ShapeSwirl and Stagger Modules
/Getting Started With the Mojs Animation Library: The Shape Module
/Getting Started With the Mojs Animation Library: The HTML Module
/Project Management Considerations for Your WordPress Project
/8 Things That Make Jest the Best React Testing Framework
/Creating an Image Editor Using CamanJS: Layers, Blend Modes, and Events
/New Short Course: Code a Front-End App With GraphQL and React
/Creating an Image Editor Using CamanJS: Applying Basic Filters
/Creating an Image Editor Using CamanJS: Creating Custom Filters and Blend Modes
/Modern Web Scraping With BeautifulSoup and Selenium
/Challenge: Create a To-Do List in React
1 /Deploy PHP Web Applications Using Laravel Forge
/Getting Started With the Mojs Animation Library: The Burst Module
/10 Things Men Can Do to Support Women in Tech
/A Gentle Introduction to Higher-Order Components in React: Best Practices
/Challenge: Build a React Component
/A Gentle Introduction to HOC in React: Learn by Example
/A Gentle Introduction to Higher-Order Components in React
/Creating Pretty Popup Messages Using SweetAlert2
/Creating Stylish and Responsive Progress Bars Using ProgressBar.js
/18 Best Contact Form PHP Scripts for 2022
/How to Make a Real-Time Sports Application Using Node.js
/Creating a Blogging App Using Angular & MongoDB: Delete Post
/Set Up an OAuth2 Server Using Passport in Laravel
/Creating a Blogging App Using Angular & MongoDB: Edit Post
/Creating a Blogging App Using Angular & MongoDB: Add Post
/Introduction to Mocking in Python
/Creating a Blogging App Using Angular & MongoDB: Show Post
/Creating a Blogging App Using Angular & MongoDB: Home
/Creating a Blogging App Using Angular & MongoDB: Login
/Creating Your First Angular App: Implement Routing
/Persisted WordPress Admin Notices: Part 4
/Creating Your First Angular App: Components, Part 2
/Persisted WordPress Admin Notices: Part 3
/Creating Your First Angular App: Components, Part 1
/How Laravel Broadcasting Works
/Persisted WordPress Admin Notices: Part 2
/Create Your First Angular App: Storing and Accessing Data
/Persisted WordPress Admin Notices: Part 1
/Error and Performance Monitoring for Web & Mobile Apps Using Raygun
/Using Luxon for Date and Time in JavaScript
7 /How to Create an Audio Oscillator With the Web Audio API
/How to Cache Using Redis in Django Applications
/20 Essential WordPress Utilities to Manage Your Site
/Introduction to API Calls With React and Axios
/Beginner’s Guide to Angular 4: HTTP
/Rapid Web Deployment for Laravel With GitHub, Linode, and RunCloud.io
/Beginners Guide to Angular 4: Routing
/Beginner’s Guide to Angular 4: Services
/Beginner’s Guide to Angular 4: Components
/Creating a Drop-Down Menu for Mobile Pages
/Introduction to Forms in Angular 4: Writing Custom Form Validators
/10 Best WordPress Booking & Reservation Plugins
/Getting Started With Redux: Connecting Redux With React
/Getting Started With Redux: Learn by Example
/Getting Started With Redux: Why Redux?
/Understanding Recursion With JavaScript
/How to Auto Update WordPress Salts
/How to Download Files in Python
/Eloquent Mutators and Accessors in Laravel
1 /10 Best HTML5 Sliders for Images and Text
/Site Authentication in Node.js: User Signup
/Creating a Task Manager App Using Ionic: Part 2
/Creating a Task Manager App Using Ionic: Part 1
/Introduction to Forms in Angular 4: Reactive Forms
/Introduction to Forms in Angular 4: Template-Driven Forms
/24 Essential WordPress Utilities to Manage Your Site
/25 Essential WordPress Utilities to Manage Your Site
/Get Rid of Bugs Quickly Using BugReplay
1 /Manipulating HTML5 Canvas Using Konva: Part 1, Getting Started
/10 Must-See Easy Digital Downloads Extensions for Your WordPress Site
/22 Best WordPress Booking and Reservation Plugins
/Understanding ExpressJS Routing
/15 Best WordPress Star Rating Plugins
/Creating Your First Angular App: Basics
/Inheritance and Extending Objects With JavaScript
/Introduction to the CSS Grid Layout With Examples
1Performant Animations Using KUTE.js: Part 5, Easing Functions and Attributes
Performant Animations Using KUTE.js: Part 4, Animating Text
/Performant Animations Using KUTE.js: Part 3, Animating SVG
/New Course: Code a Quiz App With Vue.js
/Performant Animations Using KUTE.js: Part 2, Animating CSS Properties
Performant Animations Using KUTE.js: Part 1, Getting Started
/10 Best Responsive HTML5 Sliders for Images and Text (Plus 3 Free Options)
/Single-Page Applications With ngRoute and ngAnimate in AngularJS
/Deferring Tasks in Laravel Using Queues
/Site Authentication in Node.js: User Signup and Login
/Working With Tables in React, Part Two
/Working With Tables in React, Part One
/How to Set Up a Scalable, E-Commerce-Ready WordPress Site Using ClusterCS
/New Course on WordPress Conditional Tags
/TypeScript for Beginners, Part 5: Generics
/Building With Vue.js 2 and Firebase
6 /Best Unique Bootstrap JavaScript Plugins
/Essential JavaScript Libraries and Frameworks You Should Know About
/Vue.js Crash Course: Create a Simple Blog Using Vue.js
/Build a React App With a Laravel RESTful Back End: Part 1, Laravel 5.5 API
/API Authentication With Node.js
/Beginner’s Guide to Angular: Routing
/Beginners Guide to Angular: Routing
/Beginner’s Guide to Angular: Services
/Beginner’s Guide to Angular: Components
/How to Create a Custom Authentication Guard in Laravel
/Learn Computer Science With JavaScript: Part 3, Loops
/Build Web Applications Using Node.js
/Learn Computer Science With JavaScript: Part 4, Functions
/Learn Computer Science With JavaScript: Part 2, Conditionals
/Create Interactive Charts Using Plotly.js, Part 5: Pie and Gauge Charts
/Create Interactive Charts Using Plotly.js, Part 4: Bubble and Dot Charts
Create Interactive Charts Using Plotly.js, Part 3: Bar Charts
/Awesome JavaScript Libraries and Frameworks You Should Know About
/Create Interactive Charts Using Plotly.js, Part 2: Line Charts
/Bulk Import a CSV File Into MongoDB Using Mongoose With Node.js
/Build a To-Do API With Node, Express, and MongoDB
/Getting Started With End-to-End Testing in Angular Using Protractor
/TypeScript for Beginners, Part 4: Classes
/Object-Oriented Programming With JavaScript
/10 Best Affiliate WooCommerce Plugins Compared
/Stateful vs. Stateless Functional Components in React
/Make Your JavaScript Code Robust With Flow
/Build a To-Do API With Node and Restify
/Testing Components in Angular Using Jasmine: Part 2, Services
/Testing Components in Angular Using Jasmine: Part 1
/Creating a Blogging App Using React, Part 6: Tags
/React Crash Course for Beginners, Part 3
/React Crash Course for Beginners, Part 2
/React Crash Course for Beginners, Part 1
/Set Up a React Environment, Part 4
1 /Set Up a React Environment, Part 3
/New Course: Get Started With Phoenix
/Set Up a React Environment, Part 2
/Set Up a React Environment, Part 1
/Command Line Basics and Useful Tricks With the Terminal
/How to Create a Real-Time Feed Using Phoenix and React
/Build a React App With a Laravel Back End: Part 2, React
/Build a React App With a Laravel RESTful Back End: Part 1, Laravel 9 API
/Creating a Blogging App Using React, Part 5: Profile Page
/Pagination in CodeIgniter: The Complete Guide
/JavaScript-Based Animations Using Anime.js, Part 4: Callbacks, Easings, and SVG
/JavaScript-Based Animations Using Anime.js, Part 3: Values, Timeline, and Playback
/Learn to Code With JavaScript: Part 1, The Basics
/10 Elegant CSS Pricing Tables for Your Latest Web Project
/Getting Started With the Flux Architecture in React
/Getting Started With Matter.js: The Composites and Composite Modules
Getting Started With Matter.js: The Engine and World Modules
/10 More Popular HTML5 Projects for You to Use and Study
/Understand the Basics of Laravel Middleware
/Iterating Fast With Django & Heroku
/Creating a Blogging App Using React, Part 4: Update & Delete Posts
/Creating a jQuery Plugin for Long Shadow Design
/How to Register & Use Laravel Service Providers
2 /Unit Testing in React: Shallow vs. Static Testing
/Creating a Blogging App Using React, Part 3: Add & Display Post
/Creating a Blogging App Using React, Part 2: User Sign-Up
20 /Creating a Blogging App Using React, Part 1: User Sign-In
/Creating a Grocery List Manager Using Angular, Part 2: Managing Items
/9 Elegant CSS Pricing Tables for Your Latest Web Project
/Dynamic Page Templates in WordPress, Part 3
/Angular vs. React: 7 Key Features Compared
/Creating a Grocery List Manager Using Angular, Part 1: Add & Display Items
New eBooks Available for Subscribers in June 2017
/Create Interactive Charts Using Plotly.js, Part 1: Getting Started
/The 5 Best IDEs for WordPress Development (And Why)
/33 Popular WordPress User Interface Elements
/New Course: How to Hack Your Own App
/How to Install Yii on Windows or a Mac
/What Is a JavaScript Operator?
/How to Register and Use Laravel Service Providers
/
waly Good blog post. I absolutely love this…