DEV Community

Cover image for 5 JavaScript tricks only experienced developers know... Until now! 🧙‍
Tymek Zapała
Tymek Zapała

Posted on

5 JavaScript tricks only experienced developers know... Until now! 🧙‍

JavaScript is a versatile and powerful language, but even experienced developers sometimes overlook its lesser-known features. These tricks can help you write more efficient, cleaner code that stands out. Let's dive into these five secret JavaScript maneuvers that will elevate your coding craft.

1. Destructuring for cleaner code

Destructuring is an elegant way to unpack values from arrays or objects into distinct variables. It's a must-have for making your JavaScript code more readable and concise.

Say goodbye to repetitive syntax:

// Before destructuring
const user = { name: 'Alice', age: 25 };
const name = user.name;
const age = user.age;

// With destructuring
const { name, age } = user;
Enter fullscreen mode Exit fullscreen mode

This nifty trick reduces boilerplate, letting you grab just what you need.

2. Optional chaining to avoid errors

Tired of TypeError when accessing deep nested properties? Enter optional chaining. By using the ?. operator, you can safely navigate through nested objects, only accessing properties if they exist.

const user = { profile: { email: 'alice@example.com' } };

// Without optional chaining
const email = user.profile && user.profile.email;

// With optional chaining
const email = user?.profile?.email;
Enter fullscreen mode Exit fullscreen mode

This approach makes your code cleaner and reduces the need for multiple checks.

3. The nullish coalescing operator

The ?? operator provides a convenient way to set default values only if the left-hand side is null or undefined. Often confused with the logical OR ||, this operator is a hidden gem for default fallbacks.

const input = undefined;

// Logical OR
const result = input || 'default'; // unwanted behavior with false, 0, ''

// Nullish coalescing
const result = input ?? 'default'; // better for truly null/undefined cases
Enter fullscreen mode Exit fullscreen mode

This gives more control over defaults, preventing unexpected falls to falsy values like 0 or ''.

4. Immediately Invoked Function Expressions (IIFE)

An IIFE is a function that runs as soon as it is defined. It's perfect for avoiding polluting the global scope and encapsulating code logic in a neat, self-contained package.

// IIFE Syntax
(function() {
  console.log("I'm executed immediately!");
})();
Enter fullscreen mode Exit fullscreen mode

Use IIFEs to create private scopes in your JavaScript files, preventing unwanted interference.

5. Sort without mutating: Array.toSorted()

The toSorted() method is a recent addition to JavaScript that allows you to sort an array without modifying the original. This is especially useful when you need to maintain immutability in your code.

const numbers = [3, 1, 4];
const sorted = numbers.toSorted((a, b) => a - b);

console.log(sorted); // [1, 3, 4]
console.log(numbers); // [3, 1, 4] (unchanged)
Enter fullscreen mode Exit fullscreen mode

Unlike Array.sort(), which modifies the array in place, toSorted() returns a new array, keeping the original intact and avoiding errors when we try to update immutable array.

Conclusion

Implementing these advanced JavaScript tricks can significantly improve the readability and maintainability of your codebase. By leveraging destructuring, optional chaining, nullish coalescing, IIFEs, and array toSorted(), you'll transform how you approach complex problems.

Top comments (0)