Skip to content

Bits of .NET

Daily micro-tips for C#, SQL, performance, and scalable backend engineering.

  • Asp.Net Core
  • C#
  • SQL
  • JavaScript
  • CSS
  • About
  • ErcanOPAK.com
  • No Access
  • Privacy Policy
JavaScript

JavaScript: Use Destructuring to Extract Values Cleanly

- 26.05.26 - ErcanOPAK

📦 Unpack Like Python

Accessing nested properties? const x = obj.prop.nested? Verbose. Destructuring extracts values from objects and arrays elegantly. One line replaces five.

❌ Old Way

const name = user.name;
const age = user.age;
const email = user.email;

✅ Destructuring

const { name, age, email } = user;

🎯 Advanced Patterns

// Rename variables
const { name: userName, age: userAge } = user;

// Default values
const { name, role = 'guest' } = user;

// Nested destructuring
const { address: { city, country } } = user;

// Rest operator (collect remaining properties)
const { name, ...rest } = user;

// Swap variables
[a, b] = [b, a];

// Function parameters
function greet({ name, age }) {
  console.log(`Hello ${name}, you are ${age}`);
}

📡 API Response Example

const response = {
  data: {
    user: {
      id: 123,
      profile: { name: 'Bob', avatar: 'avatar.jpg' },
      stats: { followers: 1000 }
    }
  }
};

// Extract deeply nested values in one line!
const {
  data: {
    user: {
      id: userId,
      profile: { name: userName, avatar },
      stats: { followers }
    }
  }
} = response;

💡 Pro Tips

  • Computed property names: const { [key]: value } = obj
  • Don’t overdo nesting: Deep destructuring is hard to read
  • Use TypeScript: Get autocomplete for destructured properties
  • Combine with spread: const newObj = { …user, age: 31 }

“Refactored React components to use destructuring. 50 lines of ‘const x = props.x’ became 1 line. Code so much cleaner. Should’ve learned this years ago.”

— React Developer

Related posts:

JavaScript: Use AbortController to Cancel Fetch Requests

JavaScript Code Becomes Unpredictable Over Time

AJAX Requests Timeout Randomly — Browser Connection Limits

Post Views: 4

Post navigation

HTML: Use Semantic HTML5 Elements for Better SEO and Accessibility
Ajax: Use Fetch API Instead of XMLHttpRequest for Clean Async Requests

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

June 2026
M T W T F S S
1234567
891011121314
15161718192021
22232425262728
2930  
« May    

Most Viewed Posts

  • Get the User Name and Domain Name from an Email Address in SQL (953)
  • How to add default value for Entity Framework migrations for DateTime and Bool (882)
  • Get the First and Last Word from a String or Sentence in SQL (838)
  • How to select distinct rows in a datatable in C# (808)
  • How to make theater mode the default for Youtube (805)
  • Add Constraint to SQL Table to ensure email contains @ (580)
  • How to enable, disable and check if Service Broker is enabled on a database in SQL Server (579)
  • Average of all values in a column that are not zero in SQL (538)
  • How to use Map Mode for Vertical Scroll Mode in Visual Studio (505)
  • Find numbers with more than two decimal places in SQL (454)

Recent Posts

  • C#: Use String Interpolation Instead of Concatenation
  • C#: Use Tuples to Return Multiple Values from Methods
  • SQL: Use ISNULL and NULLIF for Smart NULL Handling
  • .NET Core: Use Data Annotations for Model Validation
  • Git: Use Git Clean to Remove Untracked Files
  • Ajax: Add Custom Headers to Fetch Requests
  • JavaScript: Use console.table to Display Arrays as Tables
  • HTML: Use Spellcheck Attribute to Enable Browser Spell Check
  • CSS: Use user-select to Prevent Text Selection
  • Windows 11: Use Snipping Tool for Instant Screenshots

Most Viewed Posts

  • Get the User Name and Domain Name from an Email Address in SQL (953)
  • How to add default value for Entity Framework migrations for DateTime and Bool (882)
  • Get the First and Last Word from a String or Sentence in SQL (838)
  • How to select distinct rows in a datatable in C# (808)
  • How to make theater mode the default for Youtube (805)

Recent Posts

  • C#: Use String Interpolation Instead of Concatenation
  • C#: Use Tuples to Return Multiple Values from Methods
  • SQL: Use ISNULL and NULLIF for Smart NULL Handling
  • .NET Core: Use Data Annotations for Model Validation
  • Git: Use Git Clean to Remove Untracked Files

Social

  • ErcanOPAK.com
  • GoodReads
  • LetterBoxD
  • Linkedin
  • The Blog
  • Twitter
© 2026 Bits of .NET | Built with Xblog Plus free WordPress theme by wpthemespace.com