Kyle Shevlin

Software Engineer


Hi, I'm Kyle Shevlin, a software engineer and online instructor. This is where I share all the content I create. I mostly write articles and create courses, focusing on breaking concepts down to their fundamentals.

Peruse my blog posts, check out one of my courses (or all of them), and sign up for my newsletter if you like what you read.

If you need to reach out to me, email is the best way to do so.

Enjoy your time here and thank you.

Unsure Where to Start?

Try a post in one of these tagged collections.

ReactState MachinesFunctional ProgrammingSoftware Engineering

Recent Posts

  • Compound Components

    Keep it flexible, keep it working

    0 strokes bestowed

    Compound components are nothing new in React, but it's an advanced pattern that not everyone takes the time to learn. I want to break down how I build compound components, and make it easy for you to do the same.

    Read More
  • 0 strokes bestowed

    JSX makes writing UIs feel really familiar for frontend devs, but it can obfuscate a key detail of which we should remain aware.

  • 0 strokes bestowed

    Do you know why you might use useReducer instead of useState? There are a few key questions you can ask yourself to make that decision.

Looking for more posts?

If you're looking for more posts, visit the All Posts page.
All Posts

Let's talk some more about JavaScript, TypeScript, React, and software engineering.

I write a newsletter to share my thoughts and the projects I'm working on. I would love for you to join the conversation. You can unsubscribe at any time.

Just Enough Functional Programming Logo
Just Enough Functional Programming

Check out my courses!

Liked the post? You might like my courses, too. Click the button to view this course or go to Courses for more information.
I would like give thanks to those who have contributed fixes and updates to this blog. If you see something that needs some love, you can join them. This blog is open sourced at
©2023 Kyle Shevlin. All Rights Reserved.