How to solve the `TypeError: Attempted to assign to readonly property` error
New Courses Coming Soon
Join the waiting lists
I was doing something in my Next.js codebase when I ran into this problem:
TypeError: Attempted to assign to readonly property
Weird! After a bit of debugging I found the problem. I has nothing to do with Next.js, it can happen in any JavaScript codebase.
I had a column in my database where I stored data as JSON.
In my code I was updating this JSON object, using the dot syntax (like data.name = 'Flavio'
) but I forgot to call JSON.parse() before doing so.
data
was not an object, but a string!
Strings are immutable in JavaScript. We can’t update them once defined. Hence the error. The solution was to, obviously, call JSON.parse()
before updating the JSON object.
→ Get my JavaScript Beginner's Handbook
→ Read my
JavaScript Tutorials
on The Valley of Code
→ Read my
TypeScript Tutorial
on The Valley of Code
Here is how can I help you:
- COURSES where I teach everything I know
- CODING BOOTCAMP cohort course - next edition in 2025
- THE VALLEY OF CODE your web development manual
- BOOKS 17 coding ebooks you can download for free on JS Python C PHP and lots more
- Interesting links collection
- Follow me on X