Angular7 NgBootstrap Typeahead搜索
创始人
2024-10-22 12:00:50
0

以下是一个使用Angular 7、NgBootstrap和Typeahead搜索的示例代码:

首先,确保你已经安装了所需的依赖项。在终端中运行以下命令:

npm install @ng-bootstrap/ng-bootstrap
npm install ngx-bootstrap

在你的Angular组件中,导入所需的模块和服务:

import { Component } from '@angular/core';
import { Observable, Subject } from 'rxjs';
import { debounceTime, distinctUntilChanged, map } from 'rxjs/operators';
import { NgbTypeaheadSelectItemEvent } from '@ng-bootstrap/ng-bootstrap';

@Component({
  selector: 'app-typeahead',
  templateUrl: './typeahead.component.html',
  styleUrls: ['./typeahead.component.css']
})
export class TypeaheadComponent {
  search: string;
  searchResults: string[];
  searchSubject = new Subject();

  constructor() {
    this.searchSubject.pipe(
      debounceTime(300),
      distinctUntilChanged(),
      map(term => term.length < 2 ? [] : this.searchResults.filter(result => result.toLowerCase().indexOf(term.toLowerCase()) > -1))
    ).subscribe(results => {
      this.searchResults = results;
    });
  }

  searchTypeahead = (text$: Observable) => {
    const debouncedText$ = text$.pipe(debounceTime(200), distinctUntilChanged());
    const clicksWithClosedPopup$ = this.click$.pipe(filter(() => !this.instance.isPopupOpen()));
    const inputFocus$ = this.focus$;

    return merge(debouncedText$, inputFocus$, clicksWithClosedPopup$).pipe(
      map(term => {
        if (term === '') {
          return this.searchResults;
        } else {
          this.searchSubject.next(term);
        }
      })
    );
  }

  selectTypeaheadItem(event: NgbTypeaheadSelectItemEvent) {
    this.search = event.item;
  }
}

在你的组件模板中,使用NgBootstrap的Typeahead指令:


这样,当你在输入框中输入时,它会根据输入的内容自动搜索匹配的结果,并在下拉列表中显示。当你选择一个结果时,它会将结果赋值给search属性。

请注意,上述代码中的searchResults变量应该是一个字符串数组,其中包含你要搜索的结果。你可以根据自己的需求从API获取这些结果。

希望这可以帮助到你!

相关内容

热门资讯

第3分钟窍要!德扑之心免费透视... 第3分钟窍要!德扑之心免费透视(透视)一贯是有辅助下载(哔哩哔哩)该软件可以轻松地帮助玩家将德扑之心...
第七分钟阶段!hhpoker怎... 第七分钟阶段!hhpoker怎么破解(透视)竟然有辅助开挂(哔哩哔哩)该软件可以轻松地帮助玩家将hh...
九分钟秘籍!wepoker私人... 九分钟秘籍!wepoker私人局俱乐部辅助(透视)总是是有辅助下载(哔哩哔哩)1、这是跨平台的wep...
7分钟课程!wepoker究竟... 7分钟课程!wepoker究竟有没有透视(透视)切实是真的有辅助安装(哔哩哔哩)1、用户打开应用后不...
第三分钟教程书!wepoker... 第三分钟教程书!wepoker轻量版辅助(透视)果然有辅助教程(哔哩哔哩)该软件可以轻松地帮助玩家将...
六分钟大纲!wepoker插件... 六分钟大纲!wepoker插件辅助(透视)本来是有辅助透视(哔哩哔哩)运wepoker插件辅助辅助工...
第六分钟策略!拱趴大菠萝挂哪里... 第六分钟策略!拱趴大菠萝挂哪里(透视)好像是真的有辅助神器(哔哩哔哩)1、拱趴大菠萝挂哪里辅助软件下...
5分钟技法!wpk透视工作室(... 5分钟技法!wpk透视工作室(透视)切实是有辅助教程(哔哩哔哩)wpk透视工作室脚本下载中分为三种模...
8分钟阶段!wepoker透视... 8分钟阶段!wepoker透视脚本安卓(透视)其实有辅助下载(哔哩哔哩)1、wepoker透视脚本安...
3分钟法门!如何判断wpk辅助... 3分钟法门!如何判断wpk辅助软件的真假(透视)原来是真的有辅助教程(哔哩哔哩)1、起透看视 如何判...