在Angular 9中,你可以在一个表单中使用多个ngb-typeahead。以下是一个示例解决方法:
首先,确保你已经正确安装了ng-bootstrap和ngx-bootstrap。
接下来,创建一个新的Angular组件,并在组件的HTML模板中添加表单和多个ngb-typeahead。
在组件的TS文件中,定义search1和search2函数来处理ngb-typeahead的搜索逻辑。
import { Component } from '@angular/core';
import { Observable, Subject } from 'rxjs';
import { debounceTime, distinctUntilChanged, switchMap } from 'rxjs/operators';
@Component({
selector: 'app-example',
templateUrl: './example.component.html',
styleUrls: ['./example.component.css']
})
export class ExampleComponent {
selectedItem1: any;
selectedItem2: any;
search1 = (text$: Observable) => {
const searchSubject = new Subject();
text$.pipe(
debounceTime(200),
distinctUntilChanged(),
switchMap(term => {
// Perform your search logic here for Typeahead 1
// You can make an HTTP request or search an array of items
const results = this.searchItems(term); // Replace with your own search function
return results;
})
).subscribe(searchSubject);
return searchSubject;
}
search2 = (text$: Observable) => {
const searchSubject = new Subject();
text$.pipe(
debounceTime(200),
distinctUntilChanged(),
switchMap(term => {
// Perform your search logic here for Typeahead 2
// You can make an HTTP request or search an array of items
const results = this.searchItems(term); // Replace with your own search function
return results;
})
).subscribe(searchSubject);
return searchSubject;
}
onSelectItem1(item: any) {
// Handle the selected item for Typeahead 1
console.log('Selected item for Typeahead 1:', item);
}
onSelectItem2(item: any) {
// Handle the selected item for Typeahead 2
console.log('Selected item for Typeahead 2:', item);
}
searchItems(term: string): Observable {
// Replace this with your own search logic
// You can make an HTTP request or search an array of items
// and return the results as an Observable
const items = [
{ name: 'Item 1' },
{ name: 'Item 2' },
{ name: 'Item 3' }
];
const filteredItems = items.filter(item => item.name.toLowerCase().includes(term.toLowerCase()));
return of(filteredItems);
}
}
在上述示例中,我们使用了RxJS的操作符来处理输入的搜索逻辑。通过debounceTime和distinctUntilChanged操作符,我们可以限制对搜索功能的频繁调用。switchMap操作符用于在每次输入变化时,取消之前的搜索请求并发起新的搜索请求。
同时,我们还定义了onSelectItem1和onSelectItem2函数来处理当用户选择一个项时的逻辑。你可以在这些函数中添加你自己的代码来处理所选项的操作。
最后,我们还定义了searchItems函数来模拟搜索逻辑。你可以根据自己的需求替换这个函数,例如使用HTTP请求从服务器获取搜索结果。
希望这个示例能帮助你解决多个ngb-typeahead问题!