Creating a City State Address Selection Menu with Sample API Request in JavaScript

Introduction to Address Selection Menus

In modern web development, providing users with intuitive forms is crucial for exceptional user experiences. One common feature in forms is an address selection menu. This menu typically allows users to select their city and state, which can be critical for location-based applications, such as e-commerce sites, ride-sharing apps, and any service that relies on geographical data. In this tutorial, we will walk through the process of creating a city-state address selection menu using a sample API request to fetch location data in JavaScript.

We’ll start by discussing the importance of user-friendly interfaces and how an address selection menu can simplify data entry for users. Next, we’ll implement a JavaScript solution that utilizes an API to dynamically populate our dropdown menus for states and cities. By the end of this article, you will have a solid understanding of how to use API requests, manage state in your application, and enhance user experience.

Let’s dive into the technical details and begin building our address selection menu!

Setting Up Our Project

To get started, we’ll need a basic HTML structure and a couple of JavaScript files to hold our functionality. Create a new folder for your project and add an `index.html` file along with a `script.js` file. Here’s a basic structure for your HTML file:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Address Selection Menu</title>
    <link rel="stylesheet" href="styles.css">
</head>
<body>
    <h1>Address Selection Menu</h1>
    <div>
        <label for="state">Choose a state:</label>
        <select id="state"></select>
    </div>
    <div>
        <label for="city">Choose a city:</label>
        <select id="city"></select>
    </div>
    <script src="script.js"></script>
</body>
</html>

With our HTML structure in place, we can now focus on fetching data from a sample API that provides information about cities and states. For this article, we’ll simulate that API with a static JSON response for simplicity, although in a production environment, you would pull data from an external services’ API.

Fetching Data from the API

Next, let’s implement the JavaScript code for fetching state and city data. We will use the `fetch` API to get the data and populate our dropdown menus accordingly. This involves an async function that requests data from our ‘sample’ API and processes the response.

Create a JSON file, `data.json`, that simulates our API response:

{
  "states": [
    { "id": 1, "name": "California", "cities": ["Los Angeles", "San Francisco", "San Diego"] },
    { "id": 2, "name": "Texas", "cities": ["Houston", "Dallas", "Austin"] },
    { "id": 3, "name": "New York", "cities": ["New York City", "Buffalo", "Rochester"] }
  ]
}

In your `script.js` file, implement the following code to fetch data and populate the dropdowns:

async function populateStateCity() {
    try {
        const response = await fetch('data.json');
        const data = await response.json();

        const stateSelect = document.getElementById('state');
        data.states.forEach(state => {
            const option = document.createElement('option');
            option.value = state.id;
            option.textContent = state.name;
            stateSelect.appendChild(option);
        });
    } catch (error) {
        console.error('Error fetching state data:', error);
    }
}

populateStateCity();

This function sends a GET request to our `data.json` file, processes the JSON response, and creates option elements for each state in the dropdown. Next, we’ll implement functionality to populate the cities based on the selected state.

Handling State and City Selection

Once we have our states loaded in the dropdown, we need to create an event listener that updates the cities dropdown whenever a new state is selected. We can achieve this by adding an event listener to the state dropdown and using the selected value to filter the corresponding cities.

stateSelect.addEventListener('change', function() {
    const selectedState = data.states.find(state => state.id == stateSelect.value);
    const citySelect = document.getElementById('city');
    citySelect.innerHTML = '';

    selectedState.cities.forEach(city => {
        const option = document.createElement('option');
        option.value = city;
        option.textContent = city;
        citySelect.appendChild(option);
    });
});

Here, we listen for changes on the state dropdown. When a user selects a state, we find the corresponding state object and clear any existing options in the city dropdown before populating it with the new set of cities. This interaction enhances the overall user experience, making it intuitive and engaging.

Enhancing User Experience

While our basic selection menu is functional, we can implement a few enhancements to improve the user experience further. For instance, adding loading indicators while fetching data can inform users that their request is being processed. Additionally, we can implement error handling for network failures or empty responses.

async function populateStateCity() {
    const loadingIndicator = document.createElement('p');
    loadingIndicator.textContent = 'Loading states...';
    document.body.appendChild(loadingIndicator);

    try {
        const response = await fetch('data.json');
        const data = await response.json();
        loadingIndicator.remove();

        // Rest of your code...
    } catch (error) {
        console.error('Error fetching state data:', error);
        loadingIndicator.textContent = 'Failed to load states.';
    }
}

With these simple modifications, we provide feedback to the user during data fetching and handle potential errors gracefully, which leads to a better overall user experience.

Final Touch: CSS Styling

Now that we have a fully-functional address selection menu, let’s style it to make it visually appealing. You can add a `styles.css` file and include the following styles:

body {
    font-family: Arial, sans-serif;
    max-width: 800px;
    margin: auto;
    padding: 20px;
}

h1 {
    text-align: center;
}

label {
    display: block;
    margin: 10px 0 5px;
}

select {
    width: 100%;
    padding: 10px;
    margin-bottom: 20px;
}

With these styles applied, your address selection menu will look sleek and professional, providing a pleasing interaction for users.

Conclusion

In this tutorial, we successfully built a city-state address selection menu in JavaScript that interacts with a simulated API to provide users with relevant options based on their selections. We explored various important aspects of building such a feature, including fetching and processing data, dynamic user interfaces, and enhancing usability through thoughtful design.

By implementing the principles discussed, you can now create similar dropdown menus for your applications and take your web development skills to the next level. Keep experimenting with new frameworks and APIs, and you’ll continue to enhance your JavaScript expertise.

Feel free to customize the address selection feature further by adding more countries, integrating with actual API services, or incorporating advanced features like autocomplete. Happy coding!

Scroll to Top