DEV Community

Sharoz Tanveer🚀
Sharoz Tanveer🚀

Posted on

1

Creating Arrays in JavaScript: A Comprehensive Guide

Creating arrays in JavaScript is a fundamental task, yet there are several nuances and gotchas that even experienced developers might overlook. Let's dive into the basics and explore some interesting aspects of array creation and manipulation that you might find enlightening.

Basic Array Creation

The simplest way to create an array is using array literals:

let arr = [];
Enter fullscreen mode Exit fullscreen mode

You can then populate this array using a loop:

for (let i = 0; i < 5; i++) {
  arr.push(i);
}
Enter fullscreen mode Exit fullscreen mode

This creates an array with elements [0, 1, 2, 3, 4]. However, if you create an empty array without populating it, you'll get an array with no items and no empty slots.

Using the Array Constructor

Another way to create arrays is using the Array constructor:

let arr = Array(5);
Enter fullscreen mode Exit fullscreen mode

When a single numerical argument is passed, it creates a sparse array with the specified length but no actual elements:

console.log(arr.length); // 5
console.log(arr); // [empty Ă— 5]
Enter fullscreen mode Exit fullscreen mode

Sparse Arrays

Sparse arrays have "empty slots," which can lead to unexpected behaviour when using methods like map, filter, or forEach. These methods skip empty slots:

let arr = Array(5);
arr = arr.map((x, i) => i); // Still [empty Ă— 5]
Enter fullscreen mode Exit fullscreen mode

To populate such an array, you need to manually set values:

arr[0] = 2;
arr[4] = 3;
console.log(arr); // [2, empty Ă— 3, 3]
Enter fullscreen mode Exit fullscreen mode

Handling Sparse Arrays

To handle sparse arrays effectively, you can use methods like fill to initialise values:

let arr = Array(5).fill(1);
console.log(arr); // [1, 1, 1, 1, 1]
Enter fullscreen mode Exit fullscreen mode

But be cautious when filling with objects or arrays:

let arr = Array(5).fill({});
arr[0].name = 'John';
console.log(arr); // [{name: 'John'}, {name: 'John'}, {name: 'John'}, {name: 'John'}, {name: 'John'}]
Enter fullscreen mode Exit fullscreen mode

Each element references the same object. To avoid this, use map:

let arr = Array(5).fill(0).map(() => ({}));
arr[0].name = 'John';
console.log(arr); // [{name: 'John'}, {}, {}, {}, {}]
Enter fullscreen mode Exit fullscreen mode

Array.from Method

Array.from provides a versatile way to create arrays from array-like or iterable objects:

let arr = Array.from({ length: 5 }, (_, i) => i);
console.log(arr); // [0, 1, 2, 3, 4]
Enter fullscreen mode Exit fullscreen mode

This method can also help when creating two-dimensional arrays:

let arr2D = Array.from({ length: 5 }, () => Array(5).fill(0));
arr2D[0][0] = 1;
console.log(arr2D); // [[1, 0, 0, 0, 0], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0]]
Enter fullscreen mode Exit fullscreen mode

Iterating Over Arrays

JavaScript provides several ways to iterate over arrays, each treating sparse arrays differently:

  • for loop: Processes every index, treating empty slots as undefined.
  • for...in: Iterates over indices of the array, skipping empty slots.
  • for...of: Iterates over values, treating empty slots as undefined.

Conclusion

Understanding the intricacies of array creation and manipulation in JavaScript can help you avoid common pitfalls and write more efficient code. Whether you're using array literals, the Array constructor, or methods like Array.from and fill, knowing how these tools work will enable you to handle arrays effectively in your projects.

If you found this guide helpful, let me know. I'm always eager to create more content that delves into the nuts and bolts of JavaScript. Thank you for reading, and happy coding!

Sentry blog image

How to reduce TTFB

In the past few years in the web dev world, we’ve seen a significant push towards rendering our websites on the server. Doing so is better for SEO and performs better on low-powered devices, but one thing we had to sacrifice is TTFB.

In this article, we’ll see how we can identify what makes our TTFB high so we can fix it.

Read more

Top comments (0)

Billboard image

The Next Generation Developer Platform

Coherence is the first Platform-as-a-Service you can control. Unlike "black-box" platforms that are opinionated about the infra you can deploy, Coherence is powered by CNC, the open-source IaC framework, which offers limitless customization.

Learn more

đź‘‹ Kindness is contagious

Please leave a ❤️ or a friendly comment on this post if you found it helpful!

Okay