In this lab, we dive into Maps, a powerful data structure in JavaScript introduced with ES6. Maps allow you to store key-value pairs where keys can be of any data type, making them distinct from standard objects. Maps also maintain the insertion order of items and are optimized for lookups and updates.
- Maps: Learn to create, update, access, and delete entries in a map.
- Map Iteration and Methods: Utilize Map-specific methods for efficient data management.
- Understand how to initialize, modify, and access Map entries.
- Learn to use methods for checking key existence, counting entries, and iterating through Maps.
Your project should be structured as follows:
javascript-maps-sets/
βββ index.js
βββ README.md
-
Create a project folder named javascript-maps-sets to store your project files.
-
Inside the javascript-maps-sets folder, create a file named index.js. This will be your main JavaScript file where all your code will be written
Now that you have created the index.js
file, let's start by initializing a Map
and adding entries to it.
- Open the
index.js
file in thejavascript-maps-sets
folder and add the following code to set up aMap
and populate it with initial data.
// Working with Maps: A map is used to store key-value pairs where keys can be any type
const studentGrades = new Map();
studentGrades.set("John", 85);
studentGrades.set("Jane", 92);
studentGrades.set("Sam", 78);
Explanation:
Initialization: const studentGrades = new Map();
creates an empty Map
called studentGrades
.
Adding Entries:
studentGrades.set("John", 85);
adds an entry with the key"John"
and the value85
.studentGrades.set("Jane", 92);
adds an entry with the key"Jane"
and the value92
.studentGrades.set("Sam", 78);
adds an entry with the key"Sam"
and the value78
.
After these operations, the studentGrades
Map
will look like:
studentGrades {
"John" => 85,
"Jane" => 92,
"Sam" => 78
}
Let's move on to accessing values in a Map
and modifying them. Follow these steps to see how you can retrieve and update values in your Map
.
-
Add the following code to
index.js
to log the grade of a student:// Accessing values in a Map console.log(studentGrades.get("John")); // Output: 85
-
Run your code using Node.js in the terminal to test the
get()
method on theMap
:node index.js
85
-
Modify the existing value for
"John"
in thestudentGrades
map and log the updated value:// Modifying a value in a Map studentGrades.set("John", 88); console.log(studentGrades.get("John")); // Output: 88
- Run your code using Node.js in the terminal to test the
get()
method on theMap
again:
node index.js
- Run your code using Node.js in the terminal to test the
88
In this step, we demonstrated how to access and modify values in a Map
and observed how the output changed as a result:
Accessing the Initial Value:
- The first code snippet logged the value associated with the key
"John"
: - This initial output of
85
confirmed that the key"John"
existed in theMap
and had a grade of85
.
Modifying the Value:
- The second code snippet updated
"John"
's grade using the.set()
method: - The
.set()
method was used to change the value associated with the key"John"
from85
to88
. The updated value was then logged to confirm the modification.
Why the Output Changed:
- The
.set()
method updated the existing entry in theMap
, replacing the old value (85
) with the new value (88
). When the.get("John")
method was called again, it returned88
, confirming that the update was applied correctly.
This demonstrated how to use .set()
to modify values in a Map
and ensured that data retrieval using .get()
reflects the most recent changes.
In this step, we will use methods to check if specific keys exist in the Map
and determine the number of entries.
-
Add the following code to
index.js
to check if the key"Sam"
exists in thestudentGrades
map:// Checking if a key exists in a Map console.log(studentGrades.has("Sam")); // Output: true
Next, Let's Check the Number of Entries in the Map
- Use the following code to log the number of key-value pairs in the
studentGrades
map:
// Getting the number of entries in a Map
console.log(studentGrades.size); // Output: 3
- Run your code using Node.js in the terminal:
```bash
node index.js
```
true
3
In this section, we used two methods to interact with the studentGrades
map:
Checking if a Key Exists:
- The
.has()
method checks if a specific key is present in theMap
. The method returnedtrue
, confirming that the key"Sam"
exists in thestudentGrades
map.
Getting the Number of Entries:
- The
.size
property returns the total number of key-value pairs in theMap
. The output was3
, indicating that thestudentGrades
map contains three entries:"John"
,"Jane"
, and"Sam"
.
Why These Methods Are Useful:
- The
.has()
method is helpful for checking the presence of a key before performing operations that rely on its existence, such as retrieving or updating the value. - The
.size
property provides an immediate count of the number of entries, which is valuable for validating the number of items stored in theMap
and determining if theMap
is empty or populated.
Output:
- When both methods are run together, the combined output will be
true
(confirming that the key"Sam"
exists) and3
(showing the total number of entries in theMap
).
These steps demonstrate the effectiveness of Map
methods for key existence checks and determining the size of a Map
, making data handling and structure management straightforward.
In this step, we will explore how to use the .delete()
and .clear()
methods on a Map
.
- Use the following code to explore the delete and clear methods on the
Map
:
// Logging the value of "Sam" before deleting
console.log(`Sam's grade before deletion: ${studentGrades.get("Sam")}`); // Output: Sam's grade before deletion: 78
// Deleting an entry
studentGrades.delete("Sam");
console.log(`Sam's grade after deletion: ${studentGrades.get("Sam")}`); // Output: undefined
// Checking the size before clearing the Map
console.log(`Student Grades before clear: ${studentGrades.size}`); // Output: 2
// Clearing the Map
studentGrades.clear();
console.log(`Student Grades after clear: ${studentGrades.size}`); // Output: 0
- Run your code using Node.js in the terminal:
```bash
node index.js
```
Sam's grade before deletion: 78
Sam's grade after deletion: undefined
Student Grades before clear: 2
Student Grades after clear: 0
Logging the Value of "Sam" Before Deleting:
- We use the
.get()
method to check and display the value associated with the key"Sam"
. This confirms that"Sam"
exists in theMap
and shows its current value before any modifications are made.
Deleting an Entry:
- The
.delete()
method is used to remove the entry for"Sam"
from theMap
. After deletion, calling.get("Sam")
returnsundefined
, which indicates that the key no longer exists in theMap
. Theundefined
value in JavaScript signifies that there is no value associated with the specified key.
Checking the Size Before Clearing:
- We log the size of the
Map
using the.size
property to confirm how many key-value pairs remain after deleting"Sam"
. This helps ensure that theMap
still contains data before clearing it.
Clearing the Map:
- The
.clear()
method removes all entries from theMap
, resetting it to an empty state. Logging the size of theMap
after calling.clear()
confirms that theMap
has been emptied, as the size will be0
.
Summary
- The
.delete()
method is useful for removing specific entries from aMap
by their keys. - The
.clear()
method is used to remove all entries, effectively resetting theMap
. - The output
undefined
confirms that an attempt to access a non-existent key returns no value, indicating that the key has been removed from theMap
.
In this step, we will create a new Map
with car models and their colors, and use the .forEach()
method to iterate over the Map
and log its contents.
- Use the following code to create and iterate over a new
Map
:
// Creating a Map with car models and their colors
const carColors = new Map();
carColors.set("Toyota Corolla", "Blue");
carColors.set("Honda Civic", "Red");
carColors.set("Ford Mustang", "Black");
// Iterating over the new Map with forEach
carColors.forEach((color, car) => {
console.log(`${car}: ${color}`);
});
- Run your code using Node.js in the terminal:
```bash
node index.js
```
Toyota Corolla: Blue
Honda Civic: Red
Ford Mustang: Black
Creating a New Map:
- We create a new
Map
to store car models as keys and their corresponding colors as values. This structure allows us to associate each car model with its color in an organized manner.
Iterating Over the Map with forEach:
- The
.forEach()
method is used to iterate over theMap
. The method takes a callback function with two parameters: thevalue
(color) and thekey
(car model). This lets us access both the car model and its color during each iteration.
Logging Each Entry:
- During the iteration, we log each car model and its color to the console in the format
key: value
. This helps verify that theMap
has been populated correctly and allows us to see each entry displayed clearly.
Purpose and Benefits:
- Using
.forEach()
on aMap
makes it easy to loop through all key-value pairs, which is useful for displaying data, applying transformations, or performing operations on each entry.
- The
.forEach()
method provides an efficient way to iterate over aMap
and access each key-value pair. - Logging during the iteration confirms that data is correctly stored and retrievable.
- This approach demonstrates how to work with
Map
data structures effectively for organized data handling and display.
In this final step, youβll commit your changes and push your project to GitHub to save and share your work. This ensures that your project is versioned and backed up remotely.
-
Initialize Git (if not already initialized):
git init
-
Add All Changes to Staging:
git add .
-
Commit Your Changes:
git commit -m "Add code for working with Maps and Sets, including conversions and iterations"
-
Connect to Your GitHub Repository (if not already connected):
- Replace
<username>
with your GitHub username and<repository-name>
with the name of your repository.
git remote add origin https://github.com/<username>/<repository-name>.git
- Replace
-
Push to GitHub:
git push -u origin main
In this lab, you learned how to use JavaScript Maps to efficiently manage collections of data with flexible key-value pairings. By following each step, you gained practical experience with:
- Creating and manipulating Maps to store and access key-value pairs, enabling dynamic data management with methods like
.set()
,.get()
,.delete()
, and.clear()
. - Checking and iterating over Map entries using methods like
.has()
and.forEach()
to check for key existence, retrieve values, and display entries in a clear, organized manner. - Using Map-specific methods to handle data more efficiently, especially when insertion order or non-string keys are required, setting Maps apart from standard JavaScript objects.
- Enhanced Data Storage with Flexible Keys: Maps allow for efficient data collections where the type of the key can vary and order is preserved, which is useful for advanced data structures and efficient lookups.
- Readable and Maintainable Code: Using Maps helps create more organized and maintainable code, particularly when compared to arrays and objects in complex applications.
- Efficient Iteration and Modification: With Map-specific methods, itβs easy to add, modify, and remove entries or to clear all entries in one step, making Maps ideal for scenarios that require dynamic data manipulation.
With these skills, youβre now equipped to use JavaScript Maps to handle collections of data, streamline operations, and enhance the maintainability and scalability of your code. Continue practicing by incorporating Maps in different scenarios and combining them with other JavaScript features to build more robust and flexible applications!
π Only use this as a reference π
πΎ Not something to copy and paste πΎ
Note: This lab references a solution file located here (link not shown).
Β© All rights reserved to ThriveDX