JavaScript's Type Coercion: A Surprising Example

JavaScript Insight You Probably Didn’t Know Let’s decode a classic example that often surprises even experienced developers  console.log([] + {}); At first glance, you might expect an error. But JavaScript quietly prints: [object Object] Here’s what actually happens: The + operator triggers type coercion. [] becomes an empty string "". {} converts to "[object Object]". Final Result: "" + "[object Object]" → "[object Object]" Now, flip it: console.log({} + []); This time, the output is 0. Why? Because the first {} is treated as a block, not an object literal. That means JavaScript evaluates +[], which results in 0 Key Takeaway: JavaScript’s type coercion rules can be tricky, but mastering them helps you write cleaner, more predictable, and bug-free code. JavaScript doesn’t just execute your logic it challenges you to think differently about how data types interact. #JavaScript #WebDevelopment #FrontendDevelopment #Programming #CleanCode #Developers #SoftwareEngineering #CodingLife #TechInsights #LearnToCode

  • No alternative text description for this image

To view or add a comment, sign in

Explore content categories