使用角度2中的ngFor和ngIf应用条件

DN0*_*300 13 typescript angular

您好我曾尝试使用ngIF和ngFor过滤数组并取得一些成功.

<button *ngFor="let item of items"> <div *ngIf="(item.data.type == 1)"> {{item.data.name}} </div> </button>
Run Code Online (Sandbox Code Playgroud)

对于类型为1的数据,此代码仅显示带有名称的按钮,但它也为每个没有type = 1的数据条目创建空按钮,我无法弄清楚如何摆脱空按钮.任何帮助深表感谢.

Tyl*_*ngs 55

我将触发器您buttondiv:

<div *ngFor="let item of items">
    <button *ngIf="(item.data.type == 1)">{{item.data.name}}</button>
</div>
Run Code Online (Sandbox Code Playgroud)

这样,只为有效项创建按钮.

您还可以在组件中使用函数:

<button *ngFor="let item of filterItemsOfType('1')">{{item.data.name}}</button>
Run Code Online (Sandbox Code Playgroud)

您的组件具有以下功能:

filterItemsOfType(type){
    return this.items.filter(x => x.data.type == type);
}
Run Code Online (Sandbox Code Playgroud)

  • @Vasanth 尝试将 ngFor 放在父元素“&lt;ng-container&gt;&lt;/ng-container&gt;”上。这样就不会为每个项目渲染“th”。并将您的“span”更改为“th”。 (2认同)
  • 有很多关于在模板中使用函数以及这种模式有多糟糕的文章。请避开他们。[参考](https://medium.com/showpad-engineering/why-you-should-never-use-function-calls-in-angular-template-expressions-e1a50f9c0496) (2认同)

Jar*_* K. 18

您可以创建自己的管道.这是更好的解决方案.

@Pipe({
    name: 'somepipe',
})
export class SomePipe {

    transform(objects: any[]): any[] {
        if(objects) {
            return objects.filter(object => {
                return object.data.type === 1;
            });
        }
    }

}
Run Code Online (Sandbox Code Playgroud)

并以这种方式在html中使用它:

<button *ngFor="let item of items | somepipe"> <div> {{item.data.name}} </div> </button>
Run Code Online (Sandbox Code Playgroud)


elz*_*zoy 7

<button *ngFor="let item of getItems()">...</button>

getItems() {
  return this.items.filter((item) => item.data.type === 1);
}
Run Code Online (Sandbox Code Playgroud)

this.items该函数上方某处的项目数组在哪里?

看一下这个

  • 我不确定使用函数返回列表是否是一个好的解决方案。每次渲染 html 时都会调用该方法 (2认同)