NgbTypeahead selectItem获得点击项目ngBootstrap angular2

时间:2017-03-24 19:37:36

标签: angular bootstrap-typeahead ng-bootstrap

在这个answer中,我向我解释了使用selectItem来获取select事件。

但此时,我绑定到文本框的模型仍然是用户键入的原始文本,而不是选择项。

我用

(selectItem)="search(model)"

获取活动,并在TS

search(model) { 
this._service.search(model).subscribe(
  results => this.results = results,
  error => this.errorMessage = <any>error);

}

但如上所述,它使用用户输入的文本调用我的后端,而不是预先输入所选项目的全文。

我的后端记录

2017/03/24 20:44:14 /api/typeahead/ok
2017/03/24 20:44:14 /api/search/ok

其中第二个应该是/ api / search / $ actualSelectedItem。

1 个答案:

答案 0 :(得分:42)

您应该使用$event获取所选项目,如下所示

<input type="text" class="form-control" (selectItem)="selectedItem($event)" [(ngModel)]="model" [ngbTypeahead]="search" [resultFormatter]="formatter" />
<hr>
<pre>Model: {{ model | json }}</pre>
clicked item {{clickedItem}}

你的方法应该是

selectedItem(item){
    this.clickedItem=item.item;
    console.log(item);
  }

<强> LIVE DEMO