Skip to content Skip to sidebar Skip to footer

Using Angular2 Ngfor Index

I have this code:

Solution 1:

Angular does not provide this functionality out of the box. I think that the simplest way to achieve the desired result is to only display data on every third index like so:

<divclass="list-group"><div *ngFor="let p of products; let idx = index" ><divclass="row" *ngIf="idx % 3 === 0"><app-product [product]="products[idx]"></app-product><app-product [product]="products[idx+1]"></app-product><app-product [product]="products[idx+2]"></app-product></div></div></div>

Demo

Solution 2:

For index try this:

Controller File add function :

chunks(array, size) {
  let results = [];
  while (array.length) {
    results.push(array.splice(0, size));
  }
  return results;
};

In you view file :

<div *ngFor="let chunkProduct of chunks(products,3);" ><divclass="row"><app-product *ngFor="let product of chunkProduct" [product]="product"></app-product></div></div>

This will work for all number , not only %3 numbers.

@Teddy Sterne's solution will work incase of the number is %3 If we have 8 products it will show only 6 last 2 will be lost , in this it will also be shown.

And it will create extra blank div tags for not %3 index , if you inspect the element and check , because it will loop through each product and div will get repeated no matter if its index %3 or not.

Solution 3:

Thanks Teddy Sterne for his answer.

Here's how it helped me to create a calendar control having 7 cells in a row

<divclass="container-fluid"><tableclass="table table-bordered"><ng-container *ngFor="let d of data; let i = index" ><tr *ngIf="i % 7 === 0"><td *ngFor="let x of [i,i+1,i+2,i+3,i+4,i+5,i+6]">
          {{data[x]}}
        </td></tr></ng-container></table></div>

DEMO

https://stackblitz.com/edit/angular-1nhor2?embed=1&file=src/app/app.component.html

Post a Comment for "Using Angular2 Ngfor Index"