Home Angular Create an advanced search with autocomplete suggestions in Angular 18+ with Bootstrap 5

Create an advanced search with autocomplete suggestions in Angular 18+ with Bootstrap 5

by therichpost
0 comments
Create an advanced search with autocomplete suggestions in Angular 18+ with Bootstrap 5

Hello guys how are you? Welcome back to my blog. Today in this post I am Create an advanced search with autocomplete suggestions in Angular 18+ with Bootstrap 5.

Live Demo

Angular 18 came. If you are new then you must check below two links:

Now guys here is the complete code snippet and please follow carefully:

Since you’re using Angular 18+ with Bootstrap 5, we can achieve a similar autocomplete experience by leveraging Bootstrap’s dropdowns and Angular’s reactive forms.

Here’s how to set up an advanced search with autocomplete suggestions using Bootstrap 5:

  1. Create the Component: Set up a component to handle the search functionality with an input field and a dropdown for suggestions.
  2. HTML Template:
   <div class="position-relative">
     <input
       type="text"
       class="form-control"
       placeholder="Search..."
       [formControl]="searchControl"
       (input)="onSearch()"
     />
     <div
       *ngIf="filteredItems.length > 0"
       class="dropdown-menu show position-absolute w-100"
       style="z-index: 1"
     >
       <button
         *ngFor="let item of filteredItems"
         type="button"
         class="dropdown-item d-flex align-items-center"
         (click)="selectItem(item)"
       >
         <img
           [src]="item.image"
           alt="{{ item.title }}"
           class="me-2"
           width="24"
           height="24"
         />
         {{ item.title }}
       </button>
     </div>
   </div>
  1. Component Class:
import { Component, ViewChild, ElementRef, AfterViewInit, OnInit } from '@angular/core';
import { FormControl } from '@angular/forms';
import { ReactiveFormsModule } from '@angular/forms';
import { debounceTime } from 'rxjs/operators';

import { CommonModule } from '@angular/common'; // Import CommonModule
import { RouterLink, ActivatedRoute} from '@angular/router';
interface Item {
  title: string;
  image: string;
}
@Component({
  selector: 'app-header',
  standalone: true,
  imports: [CommonModule, ReactiveFormsModule],
  templateUrl: './header.component.html',
  styleUrl: './header.component.css'
})
export class HeaderComponent {
  

  searchControl = new FormControl();
  items: Item[] = [
    { title: 'Product 1', image: 'assets/images/buceo-catalina-430x430.jpg' },
    { title: 'Product 2', image: 'assets/images/buceo-catalina-430x430.jpg' },
    { title: 'Product 3', image: 'assets/images/buceo-catalina-430x430.jpg' },
    // Add more items here
  ];
  filteredItems: Item[] = [];

  ngOnInit() {
    this.searchControl.valueChanges.pipe(debounceTime(300)).subscribe((value) => {
      this.filteredItems = this._filter(value || '');
    });
  }

  onSearch() {
    const value = this.searchControl.value;
    this.filteredItems = this._filter(value);
  }

  private _filter(value: string): Item[] {
    const filterValue = value.toLowerCase();
    return this.items.filter((item) =>
      item.title.toLowerCase().includes(filterValue)
    );
  }

  selectItem(item: Item) {
    this.searchControl.setValue(item.title);
    this.filteredItems = [];
  }
}
  1. Styling (Optional):
   .dropdown-item img {
     width: 24px;
     height: 24px;
   }
  1. Explanation:
  • Debounce: To optimize performance, debounceTime(300) ensures the filtering function isn’t called too frequently.
  • Dynamic Dropdown: The Bootstrap dropdown appears only when there are filtered items and disappears when an item is selected.

This setup will give you a Bootstrap-based autocomplete dropdown with images and titles, all within Angular’s reactive form control structure.

I will appreciate that if you will tell your views for this post. Nothing matters if your views will be good or bad because with your views, I will make my next posts more good and helpful.

Jassa

Thanks

You may also like

Leave a Comment

This site uses Akismet to reduce spam. Learn how your comment data is processed.