我正在使用自动完成功能,因此用户可以选择地址(或搜索并选择地址)。
在同一页面上,用户可以添加地址。他们添加地址后,我想将地址添加到mat-autocomplete。
我的问题是当前mat-autocomplete没有显示任何选项。为了进行故障排除,我设置了一个使用* ngFor来显示地址的div,该div可以正常工作和更新。
//组件(省略了一些代码)
filteredAddresses_pickup;
constructor(public translate: TranslateService, private addressService:
AddressService, private route: ActivatedRoute) { }
ngOnInit() {
this.addresses = this.route.snapshot.data['addresses'];
this.filteredAddresses_pickup = Observable.create((observer: Observer<Address[]>) => {
observer.next(this.addresses);
this.addressService.addressesChanged.subscribe(
(addresses: Address[]) => {
observer.next(addresses);
this.addresses = addresses;
console.log(this.addresses);
});
this.pickupaddress.valueChanges.subscribe(value_entered => {
console.log(value_entered);
console.log(this._filterAddresses(value_entered));
observer.next(this._filterAddresses(value_entered));
});
});
}
组件HTML:
<mat-form-field class="full-width">
<input matInput placeholder="{{ 'mainapp.shipment.pickupaddress' | translate }}"
attr.aria-label="{{ 'mainapp.shipment.pickupaddress' | translate }}" [matAutocomplete]="auto"
[formControl]="pickupaddress"
>
<ng-template *ngIf="filteredAddresses_pickup | async; else loadingtwee">
<mat-autocomplete #auto="matAutocomplete" autoActiveFirstOption [displayWith]="displayAddress"><!---->
<mat-option *ngFor="let pickup of filteredAddresses_pickup | async" [value]="pickup">
<span>{{pickup.name}}, {{pickup.postalcode}}, {{pickup.country}}</span>
</mat-option>
</mat-autocomplete>
</ng-template>
</mat-form-field>
<div *ngIf="filteredAddresses_pickup | async; else loading">
<div *ngFor="let a of filteredAddresses_pickup | async">
<span>{{a.name}}, {{a.postalcode}}, {{a.country}}</span>
</div>
</div>
<ng-template #loading>
Textdiv...
</ng-template>
<ng-template #loadingtwee>
Dropdown...
</ng-template>
我看不到mat-options(它只能用作输入文本字段),但是当我在输入字段中输入内容或触发addressChanged时,我确实看到多个跨度会被过滤。
该如何解决?
答案 0 :(得分:0)
我通过移除右侧的第二个mat-autocomplete解决了该问题。我还没有正确配置第二个,它似乎干扰了第一个(没有给出错误)。
如果您有相同的问题: 删除所有其他垫自动完成功能,检查您(损坏的)垫自动完成功能是否正常,然后慢慢重新添加其他功能。
答案 1 :(得分:0)
在 style.scss 中添加这个。它应该可以解决问题。
.cdk-overlay-container, .cdk-overlay-pane { z-index: 9999 !important; }