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.
The simplest way to create an array is using array literals:
let arr = [];
You can then populate this array using a loop:
for (let i = 0; iThis 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);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]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]To populate such an array, you need to manually set values:
arr[0] = 2; arr[4] = 3; console.log(arr); // [2, empty × 3, 3]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]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'}]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'}, {}, {}, {}, {}]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]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]]Iterating Over Arrays
JavaScript provides several ways to iterate over arrays, each treating sparse arrays differently:
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!
Disclaimer: All resources provided are partly from the Internet. If there is any infringement of your copyright or other rights and interests, please explain the detailed reasons and provide proof of copyright or rights and interests and then send it to the email: [email protected] We will handle it for you as soon as possible.
Copyright© 2022 湘ICP备2022001581号-3