myHotTake

Tag: Angular route query

  • What Are Query Parameters in Angular and How Do They Work?

    If you enjoy this creative take on tech concepts, feel free to like or share


    Imagine I’m a digital treasure hunter exploring an ancient online map. This map is Angular’s routing system, helping me navigate between different islands of information (web pages). Now, when I want to visit a specific island, I’m not just landing anywhere; I’m leaving precise instructions in a bottle. These instructions? They’re the query parameters.

    Query parameters are like adding extra notes to my treasure map. For instance, let’s say I’m heading to the “Shop” island. Sure, I could just say, “Take me to the shop.” But what if I want to search for “golden amulets” or set a price range? I’d include that in my note: “Shop island, search for golden amulets, price below 500.”

    When my boat (the browser) delivers this note to the island’s dock (the routed component), the locals (the Angular code) read these details and prepare everything exactly how I asked. They set up the page to show only golden amulets under 500. Without these query parameters, I’d arrive at the island and have to search manually. Who has time for that?

    The beauty of query parameters is how flexible and easy they are. I can tweak them mid-journey without needing a new map or route. It’s like shouting back, “Oh, wait! Make it silver amulets!” and the locals adjust in real-time.

    So, query parameters in Angular are like the detailed instructions I send with my treasure map, ensuring I get precisely what I need when exploring the vast seas of a web app.


    Setting Query Parameters in Angular

    Imagine I’ve arrived at the “Shop” island, and I want to search for golden amulets with a price under 500. In Angular, I can set these query parameters dynamically using the Router:

    import { Router } from '@angular/router';
    
    constructor(private router: Router) {}
    
    goToShop() {
      this.router.navigate(['/shop'], { 
        queryParams: { 
          search: 'golden amulets', 
          price: '500' 
        } 
      });
    }
    

    Here, my query parameters (search and price) are like the notes in my treasure bottle. When I call goToShop(), Angular automatically adds these details to the URL:

    https://mytreasureapp.com/shop?search=golden+amulets&price=500
    

    Now, anyone opening this link will see only the filtered treasure they’re looking for.


    Reading Query Parameters

    Once I arrive at the “Shop” island, the locals (Angular’s component) need to read my note. For that, Angular provides the ActivatedRoute service:

    import { ActivatedRoute } from '@angular/router';
    
    constructor(private route: ActivatedRoute) {}
    
    ngOnInit() {
      this.route.queryParams.subscribe(params => {
        const search = params['search'];
        const price = params['price'];
    
        console.log(`Searching for: ${search}`);
        console.log(`Price limit: ${price}`);
      });
    }
    

    With this, my note is fully understood: the locals (code) now know I want golden amulets under 500. They’ll show me the right treasures without any extra effort on my part.


    Modifying Query Parameters

    What if I change my mind and decide I want silver amulets instead? I don’t need a whole new map—just update the note mid-journey:

    this.router.navigate([], { 
      queryParams: { 
        search: 'silver amulets' 
      }, 
      queryParamsHandling: 'merge' // Keeps existing params like price
    });
    

    This updates the URL to:

    https://mytreasureapp.com/shop?search=silver+amulets&price=500
    

    Angular makes it seamless to adjust the map without losing the existing instructions.


    Key Takeaways

    1. Query Parameters are Customizable Instructions: They fine-tune how a route behaves by passing additional information in the URL.
    2. Setting and Reading Parameters: Use Router to set them and ActivatedRoute to read them.
    3. Dynamic Updates: Query parameters can be adjusted dynamically without changing the route, making them incredibly versatile.