Angular PrimeNG 自动完成 : Displaying multiple fields?

标签 angular typescript autocomplete angular5 primeng

假设我们有这样的场景:

<p-autoComplete dataKey="id" field="make" emptyMessage="{{'NoDataFound' | translate}}"
    [delay]="0" [suggestions]="vehicles" [minLength]="0" appendTo="body"
    (completeMethod)="searchVehicles($event)" (onSelect)="on($event)">
    <ng-template let-vehicle pTemplate="item">
      {{vehicle.make}} {{vehicle.model}}
    </ng-template>
</p-autoComplete>

与 Controller :

export class AutoCompleteDemo {

    selectedVehicle: Vehicle;

    vehicles: Vehicle[];

    searchVehicles(event) {
        this.vehiclelookupservice.getResults(event.query).then(data => {
            this.vehicles= data;
        });
    }
}

Vehicle 对象的结构为:

{
    id: int,
    make: string,
    model: string
}

field 属性用于显示所选对象的属性(在本例中为make)。如何显示所选对象以显示 make + ""+ vehicle

最佳答案

您可以将 label 属性添加到您的 Vehicle 对象,然后用该对象的其他字段的串联填充它。

类似于:

this.vehiclelookupservice.getResults(event.query).then(data => {
    this.vehicles = data;
    this.vehicles.foreach(item => item.label = item.make + " " + item.vehicle);
});

然后,将 field="make" 替换为 field="label" 应该就可以了。

关于Angular PrimeNG 自动完成 : Displaying multiple fields?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65124395/

相关文章:

angular - Angular 2 中的 $broadcast $on

jquery - Rails4 自动完成功能不起作用

visual-studio - 什么是 TypeScript 项目构建配置选项?

typescript - 在 TypeScript 中将类函数作为参数传递并引用静态成员

Angular 错误 : Can't bind to 'ngForFrom' since it isn't a known property of 'a'

javascript - 使用 dojo 的 Facebook 样式自动完成

python - PyCharm 自动完成,类型列表

angular - 如何在开发模式下为 Angular 应用程序提供服务?

javascript - 如何使用 Chart.js 仅更改图表中的特定选项?

css - 检索元素样式表中的原色