JavaScript: 3 Sneaky Concepts That Trip Up Devs

💡 JavaScript: The Little Things That Fool Even Experienced Devs (Day 6/50) Ever debugged something in JavaScript that made zero sense — but later realized it was 100% logical once you understood what was happening? 😅 Let’s uncover 3 of those sneaky concepts 👇 --- ⚙️ 1️⃣ Promises vs setTimeout — Who runs first? Even if both have a 0ms delay, Promises (microtasks) run before setTimeout (macrotasks). That’s how the JavaScript Event Loop works — it always clears the microtask queue first. So, when debugging async code, remember: ✅ Promises first, then timers later. --- 🧩 2️⃣ Objects as Keys — The Silent Overwrite When you use objects as keys inside another object, JavaScript doesn’t treat them as unique objects. It converts them to the string "[object Object]". So your carefully separated keys might actually overwrite each other 😬 If you really need objects as keys → use a Map, not a plain object. --- 🎯 3️⃣ The “this” Trap in Arrow Functions Arrow functions don’t have their own this. They inherit it from the surrounding scope. That’s why this inside an arrow function often points to the wrong place (like window or undefined) — while a regular function gets its own this when called. 👉 Moral: Use normal functions when you want this to refer to your object. --- ✨ Takeaway: It’s these small but powerful details that make JavaScript fun — and frustrating 😄 Mastering them means you’re not just writing code… you’re understanding it. --- 🎥 We covered these with real code examples in Day 6 of our “50 Days of JavaScript Tricky Interview Questions” series! Watch here 👉 https://lnkd.in/g5_bPcur #javascript #webdevelopment #frontenddeveloper #backenddeveloper #asyncjavascript #eventloop #thiskeyword #objectkeys #codinginterview #learnjavascript #fullstackdeveloper #techsharingan

To view or add a comment, sign in

Explore content categories