New article in my "Building Scalable JavaScript Frameworks" series. Why JavaScript Frameworks Exist And why plain JavaScript eventually stops being enough At some point, every frontend project hits the same wall. What started as simple DOM updates turns into: – shared state everywhere – UI getting out of sync – logic duplicated across components And suddenly things start feeling fragile. Not because JavaScript is bad. But because the scale changed. Frameworks did not appear to make frontend more fashionable. They appeared to solve one core problem: 👉 keeping state and UI in sync reliably This article explores why that problem appears, and why plain JavaScript eventually stops being enough. 👉 Full article in the comments #frontend #javascript #webdevelopment
Fernando Alves’ Post
More Relevant Posts
-
Most people don’t understand the JavaScript Event Loop. So let me explain it in the simplest way possible: JavaScript is single-threaded. It can only do ONE thing at a time. It uses something called a call stack → basically a queue of things to execute. Now here’s where it gets interesting: When async code appears (like promises or setTimeout), JavaScript does NOT execute it right away. It sends it away to the Event Loop and then keeps running what’s in the call stack. Only when the call stack is EMPTY… the Event Loop starts pushing async tasks back to be executed. Now look at the code in the image. What do you think runs first? Actual output: A D C B Why? Because not all async is equal: Promises (microtasks) → HIGH priority setTimeout (macrotasks) → LOW priority So the Event Loop basically says: “Call stack is empty? cool… let me run all promises first… then I handle setTimeout” If you get this, async JavaScript stops feeling random. #javascript #webdevelopment #frontend #reactjs #softwareengineering
To view or add a comment, sign in
-
-
🔍 JavaScript Bug You Might Have Seen (typeof null === "object") You write this: console.log(typeof null); // ? What do you expect? 👉 "null" But you get: 👉 "object" 🤯 Wait… null is NOT an object… So why is JavaScript saying this? This happens because of a historical bug in JavaScript 📌 What’s going on? In the early days of JavaScript: 👉 Values were stored in a low-level format 👉 Objects were identified by a specific type tag Unfortunately… 👉 null was given the same tag as objects So: typeof null === "object" 📌 Important point: 👉 This is NOT correct behavior 👉 But it was never fixed (for backward compatibility) 📌 So how do you check for null? ❌ Don’t do this: typeof value === "null" ✔ Do this instead: value === null 💡 Takeaway: ✔ typeof null returns "object" (bug) ✔ It’s a legacy behavior in JavaScript ✔ Always check null using === null 👉 Not everything in JavaScript makes sense… some things just stayed for history 😄 🔁 Save this before it confuses you again 💬 Comment “null” if this surprised you ❤️ Like for more JavaScript deep dives #javascript #frontend #codingtips #webdevelopment #js #developer
To view or add a comment, sign in
-
🔍 JavaScript Bug You Might Have Seen (typeof null === "object") You write this: console.log(typeof null); // ? What do you expect? 👉 "null" But you get: 👉 "object" 🤯 Wait… null is NOT an object… So why is JavaScript saying this? This happens because of a historical bug in JavaScript 📌 What’s going on? In the early days of JavaScript: 👉 Values were stored in a low-level format 👉 Objects were identified by a specific type tag Unfortunately… 👉 null was given the same tag as objects So: typeof null === "object" 📌 Important point: 👉 This is NOT correct behavior 👉 But it was never fixed (for backward compatibility) 📌 So how do you check for null? ❌ Don’t do this: typeof value === "null" ✔ Do this instead: value === null 💡 Takeaway: ✔ typeof null returns "object" (bug) ✔ It’s a legacy behavior in JavaScript ✔ Always check null using === null 👉 Not everything in JavaScript makes sense… some things just stayed for history 😄 🔁 Save this before it confuses you again 💬 Comment “null” if this surprised you ❤️ Like for more JavaScript deep dives #javascript #frontend #codingtips #webdevelopment #js #developer
To view or add a comment, sign in
-
Can you explain the JavaScript event loop? Not because the concept is hard, but because explaining it clearly is what actually matters. Here’s the simplest way to break it down: JavaScript runs in a single thread, using a call stack to execute code. 1. Synchronous code runs first → Functions are pushed to the call stack and executed immediately 2. Async tasks are handled by the browser/environment → e.g. setTimeout, fetch, DOM events 3. Once the call stack is empty → the event loop starts working It processes queues in this order: 👉 Microtasks first (Promises, queueMicrotask) 👉 Then macrotasks (setTimeout, setInterval, I/O) Why? - A and D are synchronous → executed first - Promise (C) → microtask queue → runs next - setTimeout (B) → macrotask → runs last Explaining it step by step is simple — but doing it clearly makes all the difference. #Frontend #JavaScript #WebDevelopment #TechInterviews #SoftwareEngineering
To view or add a comment, sign in
-
-
🚨 JavaScript Gotcha: When 0 Actually Matters One of the most subtle bugs in JavaScript comes from using the logical OR (||) for default values. const timeout = userTimeout || 3000; Looks fine… until userTimeout = 0. 👉 JavaScript treats 0 as falsy, so instead of respecting your value, it silently replaces it with 3000. 💥 Result? Unexpected behavior. ✅ The Fix: Use Nullish Coalescing (??) const timeout = userTimeout ?? 3000; This only falls back when the value is null or undefined — not when it’s 0. 💡 When does 0 actually matter? ⏱️ Timeouts & delays → 0 can mean run immediately 📊 Counters & stats → 0 is a valid value, not “missing” 💰 Pricing / discounts → Free (0) ≠ undefined 🎚️ Sliders / configs → Minimum values often start at 0 🧠 Rule of thumb: Use || when you want to catch all falsy values (0, "", false, etc.) Use ?? when you only want to catch missing values (null, undefined) ⚡ Small operator. Big difference. Cleaner logic. #reactjs,#nodejs #JavaScript #WebDevelopment #CleanCode #Frontend #ProgrammingTips #DevTips #CodeQuality #SoftwareEngineering
To view or add a comment, sign in
-
-
Behind the Screen – #31 Do you know? JavaScript is #SingleThreaded, but it can still handle multiple tasks at once. How? JavaScript uses something called the #EventLoop. Here’s the idea: 👉 JavaScript runs one task at a time (single thread) 👉 Long tasks (like API calls, timers) are handled outside the main thread 👉 When they are ready, they are added to a queue 👉 The Event Loop picks tasks from the queue one by one So instead of doing everything at once, #JavaScript manages tasks efficiently. That’s why: • Your UI doesn’t freeze during API calls • Timers work in the background • Apps feel responsive 🔥 JavaScript doesn’t do multiple things at the same time — it manages them smartly. #javascript #webdevelopment #frontend #softwareengineering #techfacts
To view or add a comment, sign in
-
If you've spent any time reading through bundler output or older JavaScript codebases, you've almost certainly come across this pattern — an arrow function that wraps itself in parentheses and immediately calls itself. It's called an IIFE, Immediately Invoked Function Expression, and it was one of the more elegant solutions JavaScript developers came up with before native modules existed. The idea is straightforward: by wrapping the function in parentheses, you turn it into an expression rather than a declaration, which means you can invoke it right away with the trailing (). Everything defined inside stays inside — no variable leakage, no global namespace pollution, just a clean isolated scope that runs once and disappears. These days ES modules handle most of that job natively, so you won't write IIFEs as often from scratch. But understanding them still matters, partly because you'll encounter them in legacy code and bundler output, and partly because they're a good reminder of how JavaScript's scoping actually works under the hood. What's a JS pattern that confused you for longer than you'd like to admit? #JavaScript #Frontend #WebDevelopment #TypeScript
To view or add a comment, sign in
-
-
🚀 JavaScript Event Loop Explained (Must-Know Concept) Understanding the Event Loop is a game changer when it comes to writing efficient and predictable asynchronous JavaScript code. We use setTimeout, Promises, and async/await every day — but do we really know what’s happening behind the scenes? 🤔 Let’s break it down 👇 🔹 How the Event Loop Works: • JavaScript runs on a single thread • Synchronous code executes first (Call Stack) • Then Microtasks run (e.g., Promises, queueMicrotask) • Next, one Macrotask executes (e.g., setTimeout, events) • This cycle keeps repeating continuously ⚡ Execution Priority: 1️⃣ Synchronous Code 2️⃣ Microtasks 3️⃣ Macrotasks 💡 Why this matters: ✅ Helps debug async issues easily ✅ Avoids unexpected execution order ✅ Builds more predictable React apps ✅ Frequently asked in frontend interviews 📌 Pro Tip: Always remember — Promises (microtasks) run before setTimeout (macrotasks), even with 0ms delay! 💬 Are you confident with the Event Loop? Drop your thoughts below! #JavaScript #EventLoop #FrontendDevelopment #ReactJS #WebDevelopment #AsyncJavaScript #InterviewPrep #SoftwareEngineering
To view or add a comment, sign in
-
-
⚙️ How JavaScript Works Internally JavaScript may look simple, but internally it follows a powerful execution model. 🧠 Core Concepts: 👉 1. Single Threaded 🔹 JavaScript runs on a single thread → one task at a time using a call stack. 👉 2. Execution Context 🔹 Every time code runs, an execution context is created: 🔹 Global Execution Context (GEC) 🔹 Function Execution Context (FEC) 👉 3. Call Stack 🔹 Functions are pushed and popped from the stack (LIFO). 🔹 This is how JS tracks execution. 👉 4. Web APIs (Browser Features) 🔹 Async tasks like setTimeout, DOM events are handled outside the engine. 👉 5. Callback Queue & Event Loop 🔹 Completed async tasks go to the callback queue 🔹 The event loop moves them to the call stack when it’s empty 👉 6. Non-Blocking Behavior 🔹 Because of the event loop, JavaScript handles async operations without blocking execution. 🔁 Flow in Simple Terms: Call Stack → Web APIs → Callback Queue → Event Loop → Call Stack 🚀 Pro Insight: This is why JavaScript can handle async operations like APIs, timers, and user events smoothly. #JavaScript #WebDevelopment #Frontend #InterviewPrep #Developers #Coding #TechBasics
To view or add a comment, sign in
-
✨ Master JavaScript Array Destructuring for Cleaner Code Modern JavaScript lets you extract values in one line—making your code shorter, clearer, and easier to maintain. 🧠 Why it matters: Readable code = fewer bugs + faster development. ⚛️ If you’re using React, you’re already using destructuring (useState, useReducer). #JavaScript #FrontendDevelopment #WebDevelopment #ReactJS #CleanCode #ModernJS #SoftwareEngineering
To view or add a comment, sign in
-
Explore related topics
Explore content categories
- Career
- Productivity
- Finance
- Soft Skills & Emotional Intelligence
- Project Management
- Education
- Technology
- Leadership
- Ecommerce
- User Experience
- Recruitment & HR
- Customer Experience
- Real Estate
- Marketing
- Sales
- Retail & Merchandising
- Science
- Supply Chain Management
- Future Of Work
- Consulting
- Writing
- Economics
- Artificial Intelligence
- Employee Experience
- Workplace Trends
- Fundraising
- Networking
- Corporate Social Responsibility
- Negotiation
- Communication
- Engineering
- Hospitality & Tourism
- Business Strategy
- Change Management
- Organizational Culture
- Design
- Innovation
- Event Planning
- Training & Development
https://medium.com/@fernando.alves/why-javascript-frameworks-exist-c6d4f5040f90