๐ Top Free Platforms to Deploy Your Code
1๏ธโฃ Vercel
Perfect for Next.js and modern front-end apps. Fast, simple, global deployments.
โจ Ideal for portfolios, SaaS frontends, dashboards.
2๏ธโฃ Netlify
Great for static sites and JAMstack apps. Continuous deployment from Git.
โก๏ธ Quick to set up and beginner-friendly.
3๏ธโฃ GitHub Pages
Free hosting for static websites directly from your GitHub repo.
๐ Perfect for docs, portfolios, personal sites.
4๏ธโฃ Firebase Hosting
Blazing fast hosting for static and dynamic content. Backed by Google.
๐ฅ Great for PWAs, landing pages, dashboards.
5๏ธโฃ Surge
Ridiculously simple static site publishing from the command line.
โฑ๏ธ Deploy in seconds.
6๏ธโฃ Render
A strong Heroku alternative with a real free tier for web services, static sites and databases.
๐ฃ Great for hobby apps and small backends.
7๏ธโฃ Fly.io
Run lightweight apps and containers close to your users. Free allowances available.
โ๏ธ Good for small APIs and distributed apps.
8๏ธโฃ Railway
Modern, developer-friendly platform with a free tier powered by usage credits.
๐ Perfect for quick prototypes and full-stack experiments.
1๏ธโฃ Vercel
Perfect for Next.js and modern front-end apps. Fast, simple, global deployments.
โจ Ideal for portfolios, SaaS frontends, dashboards.
2๏ธโฃ Netlify
Great for static sites and JAMstack apps. Continuous deployment from Git.
โก๏ธ Quick to set up and beginner-friendly.
3๏ธโฃ GitHub Pages
Free hosting for static websites directly from your GitHub repo.
๐ Perfect for docs, portfolios, personal sites.
4๏ธโฃ Firebase Hosting
Blazing fast hosting for static and dynamic content. Backed by Google.
๐ฅ Great for PWAs, landing pages, dashboards.
5๏ธโฃ Surge
Ridiculously simple static site publishing from the command line.
โฑ๏ธ Deploy in seconds.
6๏ธโฃ Render
A strong Heroku alternative with a real free tier for web services, static sites and databases.
๐ฃ Great for hobby apps and small backends.
7๏ธโฃ Fly.io
Run lightweight apps and containers close to your users. Free allowances available.
โ๏ธ Good for small APIs and distributed apps.
8๏ธโฃ Railway
Modern, developer-friendly platform with a free tier powered by usage credits.
๐ Perfect for quick prototypes and full-stack experiments.
โค1
โ 5 Mistakes You Should Avoid When Learning Programming ๐ป
1๏ธโฃ Jumping Between Languages
Stick to one language (like Python or JavaScript) at the start. Switching too soon leads to confusion.
2๏ธโฃ Skipping Problem Solving
Donโt only watch tutorials. Practice with real coding problems to build logic and confidence.
3๏ธโฃ Not Using Version Control
Learn Git early. It helps track changes and collaborate safely.
4๏ธโฃ Avoiding Debugging
Donโt fear bugs. Debugging teaches you how code really works and improves your thinking.
5๏ธโฃ Building Without Planning
Before starting a project, plan features, structure, and flow. It saves time and avoids messy code.
1๏ธโฃ Jumping Between Languages
Stick to one language (like Python or JavaScript) at the start. Switching too soon leads to confusion.
2๏ธโฃ Skipping Problem Solving
Donโt only watch tutorials. Practice with real coding problems to build logic and confidence.
3๏ธโฃ Not Using Version Control
Learn Git early. It helps track changes and collaborate safely.
4๏ธโฃ Avoiding Debugging
Donโt fear bugs. Debugging teaches you how code really works and improves your thinking.
5๏ธโฃ Building Without Planning
Before starting a project, plan features, structure, and flow. It saves time and avoids messy code.
โค3
โ
Top Deployment Platforms for Web Developers ๐๐ป
1๏ธโฃ Netlify (Best for Frontend & Static Sites)
๐น Ideal for HTML, CSS, JavaScript, React, Vue
๐น Auto-deploys from GitHub/GitLab/Bitbucket
๐น Free SSL, custom domains, and CI/CD
๐น Built-in form handling, edge functions
๐น Great for JAMstack apps
2๏ธโฃ Heroku (Great for Full-Stack Apps)
๐น Supports Node.js, Python, Ruby, Java, etc.
๐น One-click deployment using Git or GitHub
๐น Add-ons for PostgreSQL, Redis, etc.
๐น Free tier (sleep after inactivity)
๐น Useful for MVPs, APIs, backend projects
3๏ธโฃ Vercel (Best for Next.js & Frontend Frameworks)
๐น Perfect for React, Next.js, Vue, Svelte
๐น Instant preview URLs for every push
๐น CDN-based, fast global deployment
๐น Git integration with CI/CD
๐น Automatic routing & serverless functions
๐ Other options:
- Render โ Full-stack, Postgres, CRON, free tier
- Firebase Hosting โ Realtime apps, auth, DB
- Railway โ Modern UI for backend + DB
- GitHub Pages โ Great for static project portfolios
๐ฌ Tap โค๏ธ for more!
1๏ธโฃ Netlify (Best for Frontend & Static Sites)
๐น Ideal for HTML, CSS, JavaScript, React, Vue
๐น Auto-deploys from GitHub/GitLab/Bitbucket
๐น Free SSL, custom domains, and CI/CD
๐น Built-in form handling, edge functions
๐น Great for JAMstack apps
2๏ธโฃ Heroku (Great for Full-Stack Apps)
๐น Supports Node.js, Python, Ruby, Java, etc.
๐น One-click deployment using Git or GitHub
๐น Add-ons for PostgreSQL, Redis, etc.
๐น Free tier (sleep after inactivity)
๐น Useful for MVPs, APIs, backend projects
3๏ธโฃ Vercel (Best for Next.js & Frontend Frameworks)
๐น Perfect for React, Next.js, Vue, Svelte
๐น Instant preview URLs for every push
๐น CDN-based, fast global deployment
๐น Git integration with CI/CD
๐น Automatic routing & serverless functions
๐ Other options:
- Render โ Full-stack, Postgres, CRON, free tier
- Firebase Hosting โ Realtime apps, auth, DB
- Railway โ Modern UI for backend + DB
- GitHub Pages โ Great for static project portfolios
๐ฌ Tap โค๏ธ for more!
โค4
Complete 6-month front-end roadmap to crack product-based companies in 2025:
๐ ๐ผ๐ป๐๐ต ๐ญ: ๐๐ผ๐๐ป๐ฑ๐ฎ๐๐ถ๐ผ๐ป๐ ๐ผ๐ณ ๐ช๐ฒ๐ฏ ๐๐ฒ๐๐ฒ๐น๐ผ๐ฝ๐บ๐ฒ๐ป๐
Basic HTML
- Form
- Import
- Elements
- Attributes
- Semantics
- Multimedia
- Block element
๐๐ฎ๐๐ถ๐ฐ ๐๐ฎ๐๐ฎ๐ฆ๐ฐ๐ฟ๐ถ๐ฝ๐ ๐๐ผ๐ป๐ฐ๐ฒ๐ฝ๐๐
- Scope
- Closure
- Functions
- Data types
- Event loop
๐๐ฎ๐๐ถ๐ฐ ๐๐ฆ๐ฆ ๐๐ผ๐ป๐ฐ๐ฒ๐ฝ๐๐
- Box Model
- Pseudo Classes
- Class and other selectors
- CSS type - Flex, Grid, normal
๐ ๐ผ๐ป๐๐ต ๐ฎ: ๐๐ฑ๐๐ฎ๐ป๐ฐ๐ฒ๐ฑ ๐๐ฎ๐๐ฎ๐ฆ๐ฐ๐ฟ๐ถ๐ฝ๐ ๐๐ผ๐ป๐ฐ๐ฒ๐ฝ๐๐
- How to center
- Media queries
- Bind/call/apply
- Design and CSS
- Pseudo Elements
- Class and inheritance
- Prototype and prototype chain
- All element states - active, hover
๐ ๐ผ๐ป๐๐ต ๐ฏ: ๐๐ป๐๐ฒ๐ฟ๐ฎ๐ฐ๐๐ถ๐๐ถ๐๐ & ๐ฆ๐๐๐น๐ถ๐ป๐ด
- Grid
- DOM
- Mixins
- Flexbox
- CSS constants
- Page Styling Concepts
- Event loop continuation
- Pre-processors - SCSS or LESS
๐ ๐ผ๐ป๐๐ต ๐ฐ: ๐๐ฑ๐๐ฎ๐ป๐ฐ๐ฒ๐ฑ ๐๐ฎ๐๐ฎ๐ฆ๐ฐ๐ฟ๐ถ๐ฝ๐ ๐ฎ๐ป๐ฑ ๐๐ฃ๐๐
- JWT
- XHR
- Cookie
- WebAPI
- Call stack
- Generators
- Task queue
- Async/await
- Working with Data
- APIs and Communication
- Local storage/Session storage
- REST/GraphQL/Socket connection
๐ ๐ผ๐ป๐๐ต ๐ฑ: ๐๐ผ๐บ๐ฝ๐น๐ฒ๐ ๐ช๐ฒ๐ฏ ๐๐ฒ๐๐ฒ๐น๐ผ๐ฝ๐บ๐ฒ๐ป๐ ๐ฆ๐ธ๐ถ๐น๐น๐
- CORS
- OOPs concept
- Debugging Application
- Chrome Dev Tool Features
- Understanding V8 in depth
- Front-End Engineering Practices
- Design Patterns (Singleton, Observer, Module, etc.)
๐ ๐ผ๐ป๐๐ต 6: ๐ฅ๐ฒ๐ฎ๐ฐ๐ ๐ฎ๐ป๐ฑ ๐ ๐ผ๐ฑ๐ฒ๐ฟ๐ป ๐๐ฎ๐๐ฎ๐ฆ๐ฐ๐ฟ๐ถ๐ฝ๐ ๐๐ฟ๐ฎ๐บ๐ฒ๐๐ผ๐ฟ๐ธ
- Routing
- Context API
- Virtual DOM
- React Hooks
- Custom Hooks
- State and Props
- Advanced React
- Introduction JSX
- React Ecosystem
- React Component
- Unit Testing with Jest
- Server-Side Rendering
- Redux/Flux for State Management
Apart from these, I would continuously focus on:
- Typescript
- Mocking Data
- Design Patterns in depth
- Understanding Webpack
- Advanced React patterns
- Babel, env, prettier, linter
- Tooling and Optimization
- Basic to advanced concepts for type-safety in JavaScript projects.
๐ฌ Tap โค๏ธ for more!
๐ ๐ผ๐ป๐๐ต ๐ญ: ๐๐ผ๐๐ป๐ฑ๐ฎ๐๐ถ๐ผ๐ป๐ ๐ผ๐ณ ๐ช๐ฒ๐ฏ ๐๐ฒ๐๐ฒ๐น๐ผ๐ฝ๐บ๐ฒ๐ป๐
Basic HTML
- Form
- Import
- Elements
- Attributes
- Semantics
- Multimedia
- Block element
๐๐ฎ๐๐ถ๐ฐ ๐๐ฎ๐๐ฎ๐ฆ๐ฐ๐ฟ๐ถ๐ฝ๐ ๐๐ผ๐ป๐ฐ๐ฒ๐ฝ๐๐
- Scope
- Closure
- Functions
- Data types
- Event loop
๐๐ฎ๐๐ถ๐ฐ ๐๐ฆ๐ฆ ๐๐ผ๐ป๐ฐ๐ฒ๐ฝ๐๐
- Box Model
- Pseudo Classes
- Class and other selectors
- CSS type - Flex, Grid, normal
๐ ๐ผ๐ป๐๐ต ๐ฎ: ๐๐ฑ๐๐ฎ๐ป๐ฐ๐ฒ๐ฑ ๐๐ฎ๐๐ฎ๐ฆ๐ฐ๐ฟ๐ถ๐ฝ๐ ๐๐ผ๐ป๐ฐ๐ฒ๐ฝ๐๐
- How to center
- Media queries
- Bind/call/apply
- Design and CSS
- Pseudo Elements
- Class and inheritance
- Prototype and prototype chain
- All element states - active, hover
๐ ๐ผ๐ป๐๐ต ๐ฏ: ๐๐ป๐๐ฒ๐ฟ๐ฎ๐ฐ๐๐ถ๐๐ถ๐๐ & ๐ฆ๐๐๐น๐ถ๐ป๐ด
- Grid
- DOM
- Mixins
- Flexbox
- CSS constants
- Page Styling Concepts
- Event loop continuation
- Pre-processors - SCSS or LESS
๐ ๐ผ๐ป๐๐ต ๐ฐ: ๐๐ฑ๐๐ฎ๐ป๐ฐ๐ฒ๐ฑ ๐๐ฎ๐๐ฎ๐ฆ๐ฐ๐ฟ๐ถ๐ฝ๐ ๐ฎ๐ป๐ฑ ๐๐ฃ๐๐
- JWT
- XHR
- Cookie
- WebAPI
- Call stack
- Generators
- Task queue
- Async/await
- Working with Data
- APIs and Communication
- Local storage/Session storage
- REST/GraphQL/Socket connection
๐ ๐ผ๐ป๐๐ต ๐ฑ: ๐๐ผ๐บ๐ฝ๐น๐ฒ๐ ๐ช๐ฒ๐ฏ ๐๐ฒ๐๐ฒ๐น๐ผ๐ฝ๐บ๐ฒ๐ป๐ ๐ฆ๐ธ๐ถ๐น๐น๐
- CORS
- OOPs concept
- Debugging Application
- Chrome Dev Tool Features
- Understanding V8 in depth
- Front-End Engineering Practices
- Design Patterns (Singleton, Observer, Module, etc.)
๐ ๐ผ๐ป๐๐ต 6: ๐ฅ๐ฒ๐ฎ๐ฐ๐ ๐ฎ๐ป๐ฑ ๐ ๐ผ๐ฑ๐ฒ๐ฟ๐ป ๐๐ฎ๐๐ฎ๐ฆ๐ฐ๐ฟ๐ถ๐ฝ๐ ๐๐ฟ๐ฎ๐บ๐ฒ๐๐ผ๐ฟ๐ธ
- Routing
- Context API
- Virtual DOM
- React Hooks
- Custom Hooks
- State and Props
- Advanced React
- Introduction JSX
- React Ecosystem
- React Component
- Unit Testing with Jest
- Server-Side Rendering
- Redux/Flux for State Management
Apart from these, I would continuously focus on:
- Typescript
- Mocking Data
- Design Patterns in depth
- Understanding Webpack
- Advanced React patterns
- Babel, env, prettier, linter
- Tooling and Optimization
- Basic to advanced concepts for type-safety in JavaScript projects.
๐ฌ Tap โค๏ธ for more!
โค2
โ
HTML Basics You Must Know ๐งฑ๐
HTML (HyperText Markup Language) is the foundation of every web page. It structures content like text, images, links, and forms.
1๏ธโฃ Basic HTML Structure
Explanation:
โฆ
โฆ
โฆ
โฆ
2๏ธโฃ Headings and Paragraphs
3๏ธโฃ Links and Images
4๏ธโฃ Lists
5๏ธโฃ Tables
6๏ธโฃ Forms
7๏ธโฃ Div & Span
โฆ
โฆ
๐ก Practice HTML in a live editor like CodePen or JSFiddle to see instant results!
๐ฌ Tap โค๏ธ for more!
HTML (HyperText Markup Language) is the foundation of every web page. It structures content like text, images, links, and forms.
1๏ธโฃ Basic HTML Structure
<!DOCTYPE html>
<html>
<head>
<title>My First Page</title>
</head>
<body>
<h1>Hello World!</h1>
<p>This is a paragraph.</p>
</body>
</html>
Explanation:
โฆ
<!DOCTYPE html> โ Declares HTML5โฆ
<html> โ Root elementโฆ
<head> โ Info about the page (title, meta)โฆ
<body> โ Visible content2๏ธโฃ Headings and Paragraphs
<h1>Main Heading</h1>
<h2>Subheading</h2>
<p>This is a paragraph.</p>
3๏ธโฃ Links and Images
<a href="https://google.com">Visit Google</a>
<img src="image.jpg" alt="Image" width="200">
4๏ธโฃ Lists
<ul>
<li>HTML</li>
<li>CSS</li>
</ul>
<ol>
<li>Step 1</li>
<li>Step 2</li>
</ol>
5๏ธโฃ Tables
<table border="1">
<tr>
<th>Name</th>
<th>Age</th>
</tr>
<tr>
<td>Alice</td>
<td>25</td>
</tr>
</table>
6๏ธโฃ Forms
<form>
<input type="text" placeholder="Your name">
<input type="email" placeholder="Your email">
<button type="submit">Submit</button>
</form>
7๏ธโฃ Div & Span
โฆ
<div> โ Block-level containerโฆ
<span> โ Inline container<div style="background: lightgray;">Box</div>
<span style="color: red;">Text</span>
๐ก Practice HTML in a live editor like CodePen or JSFiddle to see instant results!
๐ฌ Tap โค๏ธ for more!
โค2๐1
โ
CSS Basics You Should Know ๐จ๐ป
CSS (Cascading Style Sheets) is used to style HTML elements โ adding colors, spacing, layout, and more.
1๏ธโฃ CSS Syntax
Example:
2๏ธโฃ How to Add CSS
โฆ Inline:
โฆ Internal (within HTML):
โฆ External (best practice):
3๏ธโฃ Selectors
โฆ
โฆ
โฆ
โฆ
4๏ธโฃ Colors & Fonts
5๏ธโฃ Box Model
Every HTML element is a box:
content + padding + border + margin
6๏ธโฃ Layout with Flexbox
7๏ธโฃ Responsive Design
8๏ธโฃ Hover Effects
9๏ธโฃ Common Properties
โฆ
โฆ
โฆ
โฆ
โฆ
โฆ
๐ก Tip: Organize your styles using class names and external CSS files for better scalability.
๐ฌ Tap โค๏ธ for more!
CSS (Cascading Style Sheets) is used to style HTML elements โ adding colors, spacing, layout, and more.
1๏ธโฃ CSS Syntax
selector {
property: value;
}Example:
h1 {
color: blue;
font-size: 32px;
}2๏ธโฃ How to Add CSS
โฆ Inline:
<p style="color: red;">Hello</p>
โฆ Internal (within HTML):
<style>
p { color: green; }
</style>
โฆ External (best practice):
<link rel="stylesheet" href="style.css">
3๏ธโฃ Selectors
โฆ
* โ All elementsโฆ
p โ All <p> tagsโฆ
.class โ Elements with classโฆ
#id โ Element with specific ID#title { color: blue; }.red-text { color: red; }4๏ธโฃ Colors & Fonts
body {
background-color: #f2f2f2;
color: #333;
font-family: Arial, sans-serif;
}5๏ธโฃ Box Model
Every HTML element is a box:
content + padding + border + margin
6๏ธโฃ Layout with Flexbox
{
display: flex;
justify-content: space-between;
align-items: center;
}7๏ธโฃ Responsive Design
@media (max-width: 600px) {
body {
font-size: 14px;
}
}8๏ธโฃ Hover Effects
button:hover {
background-color: black;
color: white;
}9๏ธโฃ Common Properties
โฆ
color โ Text colorโฆ
background-color โ Backgroundโฆ
margin & padding โ Spacingโฆ
border โ Border styleโฆ
width / height โ Sizeโฆ
text-align โ Alignment๐ก Tip: Organize your styles using class names and external CSS files for better scalability.
๐ฌ Tap โค๏ธ for more!
๐ฅ3
โ
JavaScript Basics You Should Know ๐โจ
JavaScript is a scripting language used to make websites interactive handling user actions, animations, and dynamic content.
1๏ธโฃ Variables & Data Types
Use
Data Types: string, number, boolean, object, array, null, undefined.
2๏ธโฃ Functions
Reusable blocks of code.
Or use arrow functions for concise syntax:
3๏ธโฃ Conditionals
4๏ธโฃ Loops
5๏ธโฃ Arrays & Objects
6๏ธโฃ DOM Manipulation
7๏ธโฃ Event Listeners
8๏ธโฃ Fetch API (Async)
9๏ธโฃ ES6 Features
โฆ
โฆ Arrow functions
โฆ Template literals:
โฆ Destructuring:
โฆ Spread/rest operators:
๐ก Tip: Practice JS in browser console or use online editors like JSFiddle / CodePen.
๐ฌ Tap โค๏ธ for more!
JavaScript is a scripting language used to make websites interactive handling user actions, animations, and dynamic content.
1๏ธโฃ Variables & Data Types
Use
let for reassignable variables, const for constants (avoid var due to scoping issues).let name = "Alex";
const age = 25;
Data Types: string, number, boolean, object, array, null, undefined.
2๏ธโฃ Functions
Reusable blocks of code.
function greet(user) {
return `Hello, ${user}`;
}Or use arrow functions for concise syntax:
const greet = (user) => `Hello, ${user}`;3๏ธโฃ Conditionals
if (age > 18) {
console.log("Adult");
} else {
console.log("Minor");
}4๏ธโฃ Loops
for (let i = 0; i < 5; i++) {
console.log(i);
}5๏ธโฃ Arrays & Objects
let fruits = ["apple", "banana"];
let person = { name: "John", age: 30 };
6๏ธโฃ DOM Manipulation
document.getElementById("demo").textContent = "Updated!";7๏ธโฃ Event Listeners
button.addEventListener("click", () => alert("Clicked!"));8๏ธโฃ Fetch API (Async)
fetch("https://api.example.com").then(res => res.json()).then(data => console.log(data));9๏ธโฃ ES6 Features
โฆ
let, constโฆ Arrow functions
โฆ Template literals:
Hello ${name}โฆ Destructuring:
const { name } = person;โฆ Spread/rest operators:
...fruits๐ก Tip: Practice JS in browser console or use online editors like JSFiddle / CodePen.
๐ฌ Tap โค๏ธ for more!
โค1๐ฅ1
โ
JavaScript Advanced Concepts You Should Know ๐๐ป
These concepts separate beginner JS from production-level code. Understanding them helps with async patterns, memory, and modular apps.
1๏ธโฃ Closures
A function that "closes over" variables from its outer scope, maintaining access even after the outer function returns. Useful for data privacy and state management.
2๏ธโฃ Promises & Async/Await
Promises handle async operations; async/await makes them read like sync code. Essential for APIs, timers, and non-blocking I/O.
3๏ธโฃ Hoisting
Declarations (var, function) are moved to the top of their scope during compilation, but initializations stay put. let/const are block-hoisted but in a "temporal dead zone."
4๏ธโฃ The Event Loop
JS is single-threaded; the event loop processes the call stack, then microtasks (Promises), then macrotasks (setTimeout). Explains why async code doesn't block.
5๏ธโฃ this Keyword
Dynamic binding: refers to the object calling the method. Changes with call site, new, or explicit binding.
6๏ธโฃ Spread & Rest Operators
Spread (...) expands iterables; rest collects arguments into arrays.
7๏ธโฃ Destructuring
Extract values from arrays/objects into variables.
8๏ธโฃ Call, Apply, Bind
Explicitly set 'this' context. Call/apply invoke immediately; bind returns a new function.
9๏ธโฃ IIFE (Immediately Invoked Function Expression)
Self-executing function to create private scope, avoiding globals.
๐ Modules (import/export)
ES6 modules for code organization and dependency management.
๐ก Practice these in a Node.js REPL or browser console to see how they interact.
๐ฌ Tap โค๏ธ if you're learning something new!
These concepts separate beginner JS from production-level code. Understanding them helps with async patterns, memory, and modular apps.
1๏ธโฃ Closures
A function that "closes over" variables from its outer scope, maintaining access even after the outer function returns. Useful for data privacy and state management.
function outer() {
let count = 0;
return function inner() {
count++;
console.log(count);
};
}
const counter = outer();
counter(); // 1
counter(); // 22๏ธโฃ Promises & Async/Await
Promises handle async operations; async/await makes them read like sync code. Essential for APIs, timers, and non-blocking I/O.
// Promise chain
fetch(url).then(res => res.json()).then(data => console.log(data)).catch(err => console.error(err));
// Async/Await (cleaner)
async function getData() {
try {
const res = await fetch(url);
const data = await res.json();
console.log(data);
} catch (err) {
console.error(err);
}
}
3๏ธโฃ Hoisting
Declarations (var, function) are moved to the top of their scope during compilation, but initializations stay put. let/const are block-hoisted but in a "temporal dead zone."
console.log(x); // undefined (hoisted, but not initialized)
var x = 5;
console.log(y); // ReferenceError (temporal dead zone)
let y = 10;
4๏ธโฃ The Event Loop
JS is single-threaded; the event loop processes the call stack, then microtasks (Promises), then macrotasks (setTimeout). Explains why async code doesn't block.
5๏ธโฃ this Keyword
Dynamic binding: refers to the object calling the method. Changes with call site, new, or explicit binding.
const obj = {
name: "Sam",
greet() {
console.log(`Hi, I'm ${this.name}`);
},
};
obj.greet(); // "Hi, I'm Sam"
// In arrow function, this is lexical
const arrowGreet = () => console.log(this.name); // undefined in global6๏ธโฃ Spread & Rest Operators
Spread (...) expands iterables; rest collects arguments into arrays.
const nums = [1, 2, 3];
const more = [...nums, 4]; // [1, 2, 3, 4]
function sum(...args) {
return args.reduce((a, b) => a + b, 0);
}
sum(1, 2, 3); // 6
7๏ธโฃ Destructuring
Extract values from arrays/objects into variables.
const person = { name: "John", age: 30 };
const { name, age } = person; // name = "John", age = 30
const arr = [1, 2, 3];
const [first, second] = arr; // first = 1, second = 28๏ธโฃ Call, Apply, Bind
Explicitly set 'this' context. Call/apply invoke immediately; bind returns a new function.
function greet() {
console.log(`Hi, I'm ${this.name}`);
}
greet.call({ name: "Tom" }); // "Hi, I'm Tom"
const boundGreet = greet.bind({ name: "Alice" });
boundGreet(); // "Hi, I'm Alice"9๏ธโฃ IIFE (Immediately Invoked Function Expression)
Self-executing function to create private scope, avoiding globals.
(function() {
console.log("Runs immediately");
let privateVar = "hidden";
})();๐ Modules (import/export)
ES6 modules for code organization and dependency management.
// math.js
export const add = (a, b) => a + b;
export default function multiply(a, b) { return a * b; }
// main.js
import multiply, { add } from './math.js';
console.log(add(2, 3)); // 5
๐ก Practice these in a Node.js REPL or browser console to see how they interact.
๐ฌ Tap โค๏ธ if you're learning something new!
โค3