我有一个显示参与者列表的项目。我想做的是由提供商使用复选框实时过滤它们。
参与者:
[
{ 'name': 'test1', 'provider' : {'name': 'provider1'}}
{ 'name': 'test2', 'provider' : {'name': 'provider2'}}
{ 'name': 'test3', 'provider' : {'name': 'provider3'}}
{ 'name': 'test4', 'provider' : {'name': 'provider1'}'}
..
]
我的html模板是:
这是显示提供程序的复选框列表。我用它来过滤参与者。
<div class="form-group" *ngFor="let provider of providers">
<input type="checkbox" name="providers" value="{{ provider.name }}" [(ngModel)]="provider.checked"
(change)="displayParticipantsByProvider($event.target.value)">{{ provider.lastName }}
</div>
这是我显示参与者的方式:
<ul>
<li *ngFor="let p of participants">{{ p.name }} - {{ p.provider.name }} </li>
</ul>
我在组件中的过滤器功能是:
displayParticipantsByProvider(filterVal: any) {
if (filterVal === '0') {
this.participants = this.cathechParticipants;
} else {
this.participants = this.participants.filter((item) => item.provider.includes(filterVal));
}
}
此过滤器仅返回已选中的项目。例如,如果从复选框中选择了提供者1,它将返回参与者,其中有我提供者1。如果我从复选框中选择了provider2,它将仅返回其中带有provider2的参与者。我的目标是加载它们,因为它们都被选中了。那么,如何使用多个允许我过滤的复选框加载参与者?
答案 0 :(得分:1)
跟踪所选项目并将其与提供者列表匹配,并将其添加到参与者数组。
以下示例是使用Angular Material完成的。
export class AppComponent {
selectedProviders: any[];
providers: any[];
participants: any[];
providerChange() {
this.participants = [];
for (const sp of this.selectedProviders) {
for (const p of this.providers) {
if (sp.provider.name === p.provider.name) {
this.participants.push(p);
}
}
}
}
ngOnInit() {
this.providers = [
{ 'name': 'test1', 'provider': { 'name': 'provider1' } },
{ 'name': 'test2', 'provider': { 'name': 'provider2' } },
{ 'name': 'test3', 'provider': { 'name': 'provider3' } },
{ 'name': 'test4', 'provider': { 'name': 'provider1' } }
]
}
}
HTML:
<mat-list-item class="primary-imenu-item" role="listitem">
<mat-form-field class="select-form">
<mat-select
placeholder="Providers"
name="providers"
class="filter-select"
[(ngModel)]="selectedProviders"
(change)="providerChange()"
multiple>
<mat-option *ngFor="let p of providers" [value]="p">
{{p.provider.name}}
</mat-option>
</mat-select>
</mat-form-field>
</mat-list-item>
<ul>
<li *ngFor="let p of participants">{{p.name}}</li>
</ul>
答案 1 :(得分:0)
您可以检查提供程序的列表,并查看哪些提供程序的'checked'属性设置为true(将使用ngModel绑定)
答案 2 :(得分:0)
HTML代码
<div class="form-group" *ngFor="let provider of providers;let i = index">
<input type="checkbox" name="providers" value="{{ provider.name }}" [(ngModel)]="provider.checked"
(change)="displayParticipantsByProvider()"><span class="font-weight-bold">{{ provider.name }}</span>
</div>
<ul>
<li *ngFor="let p of participants">{{ p.name }} - {{ p.provider.name }} </li>
</ul>
TS代码
participants = [];
providers = [
{ 'name': 'test1', 'provider' : {'name': 'provider1'}, checked: false},
{ 'name': 'test2', 'provider' : {'name': 'provider2'}, checked: false},
{ 'name': 'test3', 'provider' : {'name': 'provider3'}, checked: false},
{ 'name': 'test4', 'provider' : {'name': 'provider1'}, checked: false}
];
displayParticipantsByProvider() {
this.participants = this.providers.filter((item, idx) => {
if (item.checked) {
return item;
}
});
}