Skip to content

Latest commit

Β 

History

History
370 lines (243 loc) Β· 14 KB

README.md

File metadata and controls

370 lines (243 loc) Β· 14 KB

JavaScript Advanced: Working with Maps

Screenshot showing the JavaScript code solution implementing Maps  with operations such as adding, deleting, and converting data structures.


Description πŸ“„

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.

Key Concepts Covered:

  • Maps: Learn to create, update, access, and delete entries in a map.
  • Map Iteration and Methods: Utilize Map-specific methods for efficient data management.

By the end of this lab, you will:

  • Understand how to initialize, modify, and access Map entries.
  • Learn to use methods for checking key existence, counting entries, and iterating through Maps.

Expected Project Structure πŸ—οΈ

Your project should be structured as follows:

javascript-maps-sets/
β”œβ”€β”€ index.js
└── README.md

1. Create the Project Folder and Files

  • 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

2. Setting Up Your Map

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 the javascript-maps-sets folder and add the following code to set up a Map 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 value 85.
  • studentGrades.set("Jane", 92); adds an entry with the key "Jane" and the value 92.
  • studentGrades.set("Sam", 78); adds an entry with the key "Sam" and the value 78.

Visual Representation:

After these operations, the studentGrades Map will look like:

studentGrades {
  "John" => 85,
  "Jane" => 92,
  "Sam" => 78
}

3. Accessing and Modifying Values in a Map

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 the Map:

    node index.js

Expected Output:

85
  • Modify the existing value for "John" in the studentGrades 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 the Map again:
    node index.js

Expected Output:

88

Explanation

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 the Map and had a grade of 85.

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" from 85 to 88. The updated value was then logged to confirm the modification.

Why the Output Changed:

  • The .set() method updated the existing entry in the Map, replacing the old value (85) with the new value (88). When the .get("John") method was called again, it returned 88, 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.

4. Checking for the Existence of Keys and the Size of a Map

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 the studentGrades 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
```

Expected Output:

true
3

Explanation

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 the Map. The method returned true, confirming that the key "Sam" exists in the studentGrades map.

Getting the Number of Entries:

  • The .size property returns the total number of key-value pairs in the Map. The output was 3, indicating that the studentGrades 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 the Map and determining if the Map is empty or populated.

Output:

  • When both methods are run together, the combined output will be true (confirming that the key "Sam" exists) and 3 (showing the total number of entries in the Map).

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.

5. Now Let's Look at the Delete and Clear Methods

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
```

Expected Output:

Sam's grade before deletion: 78
Sam's grade after deletion: undefined
Student Grades before clear: 2
Student Grades after clear: 0

Explanation

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 the Map 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 the Map. After deletion, calling .get("Sam") returns undefined, which indicates that the key no longer exists in the Map. The undefined 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 the Map still contains data before clearing it.

Clearing the Map:

  • The .clear() method removes all entries from the Map, resetting it to an empty state. Logging the size of the Map after calling .clear() confirms that the Map has been emptied, as the size will be 0.

Summary

  • The .delete() method is useful for removing specific entries from a Map by their keys.
  • The .clear() method is used to remove all entries, effectively resetting the Map.
  • The output undefined confirms that an attempt to access a non-existent key returns no value, indicating that the key has been removed from the Map.

6. Creating Another Map and Using forEach

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
```

Expected Output:

Toyota Corolla: Blue
Honda Civic: Red
Ford Mustang: Black

Explanation

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 the Map. The method takes a callback function with two parameters: the value (color) and the key (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 the Map has been populated correctly and allows us to see each entry displayed clearly.

Purpose and Benefits:

  • Using .forEach() on a Map makes it easy to loop through all key-value pairs, which is useful for displaying data, applying transformations, or performing operations on each entry.

Summary

  • The .forEach() method provides an efficient way to iterate over a Map 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.

7. Commit and Push Your Project to GitHub

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
  • Push to GitHub:

    git push -u origin main

Conclusion πŸ“„

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.

Key Takeaways:

  • 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!

Solution codebase πŸ‘€

πŸ›‘ 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