DEV Community

Cover image for I hate Server Actions in Next.js
Muneeb Hussain
Muneeb Hussain

Posted on

1

I hate Server Actions in Next.js

Don't get angry, Just listen to me

Ask yourself few questions

  1. Why you hate PHP?
  2. How much time it will take for you to build simple crud based APIs in Node.js (with a framework of your choice) and then integrating them into React.js app (client-side)?
  3. Will you fix something which isn't broken?

Let me answer these questions for you

  1. I don't like it's syntax, why explode when I can split and It's traditional way of full-stack development which merges (--force) server and client together that makes it way harder to debug.
  2. I have a boilerplate, so it will take 1 hour or maybe less.
  3. NO! NEVER!

Let's pull Next.js into the game.

  1. Isn't Next.js doing same but the cool way.
  2. What's the point of using server actions then and pushing my self into hell of bugs?
  3. So why Next.js did this, we don't need it, we don't ask for it.

I know some of you already got triggered because you have put countless hours debugging your server actions and server components bugs and now you can call yourself a Ninja-level Next.js Geek because at some point with the help of prayers of your parents, you are able to find fixes for each of the bug - Congrats BTW

For those who are listening with patience, let's continue.

I have used Server Actions, they seem to be great at first glance but when I use them in my projects, Oh man, I got lost into the pool of bugs, unhelpful error messages and what's not, I literally got crazy at point where my manager is continuously following me for update and I'm resolving a bug related to "headers" which has appeared during production build and not in dev environment, and that's not just one time incident.

Incidents like this happens time by time and I realize that for building simple applications, I got into numerous amount of bugs and my code looks like a sh*t, what will happen when I take it to complex projects (I just don't want to imagine), why I'm wasting my time, I can just do that in couple of hours If I just create a separate project for backend and build APIs for everything.

And guess what? I did the same, and then I'm able to take a deep breath of fresh air and my mental health is stable now. It takes just 2 days (dedicatedly) for me to transform all server actions into Node.js (express) based APIs and integrating them with axios and React Query. It works like a charm, No performance issues, No weird bugs, No cache issues, I can deploy it anywhere, All set and running in Production peacefully.

Here's what I have learned during all this cumbersome.

  1. Don't run after shiny trends for a sake of looking cool.
  2. Don't ever try any new feature (which seems to be providing a solution that needs a problem) into your production code or just don't waste your time on that.
  3. Stability always and forever wins.
  4. The problem you solve matters, the feature or the way you use to solve it doesn't.
  5. Experience of a developer is worth more than Developer Experience or DX

And the most important one

Don't use Server Actions

If someone from React's Core Team or Next.js Core Team reading this, My friend do focus on frontend, there's a lot more to explore, although you are doing great but React's state management sucks, React's performance sucks, fix them first then move to backend side of things, Take inspiration from your friends such as Angular and Vue.

That's it. Have a good day. Don't take it personally

Image of AssemblyAI tool

Challenge Submission: SpeechCraft - AI-Powered Speech Analysis for Better Communication

SpeechCraft is an advanced real-time speech analytics platform that transforms spoken words into actionable insights. Using cutting-edge AI technology from AssemblyAI, it provides instant transcription while analyzing multiple dimensions of speech performance.

Read full post

Top comments (2)

Collapse
 
mrlectus profile image
LectusMan

Did you use hono

Collapse
 
davidarmendariz profile image
David Armendáriz

Agree

Image of AssemblyAI

Automatic Speech Recognition with AssemblyAI

Experience near-human accuracy, low-latency performance, and advanced Speech AI capabilities with AssemblyAI's Speech-to-Text API. Sign up today and get $50 in API credit. No credit card required.

Try the API

👋 Kindness is contagious

Explore a sea of insights with this enlightening post, highly esteemed within the nurturing DEV Community. Coders of all stripes are invited to participate and contribute to our shared knowledge.

Expressing gratitude with a simple "thank you" can make a big impact. Leave your thanks in the comments!

On DEV, exchanging ideas smooths our way and strengthens our community bonds. Found this useful? A quick note of thanks to the author can mean a lot.

Okay