Как мне обработать данные в виде вложенных массивов в json? - PullRequest
0 голосов
/ 20 июня 2019

В этом случае у меня возникла проблема с созданием таблицы данных. данные, которыми я буду управлять, - это вложенный массив объектов json, поэтому я надеюсь найти ответ здесь:)

Это пример фрагмента кода, который я мог бы использовать.

{{ user?.referredUser?.list[0]?.status }}

Но это не подходит, потому что позже этот список пользователей будет продолжать расти вместе с количеством пользователей.

<table class="table table-hover table-condensed" id="DataTable" [mfData]="referred" #mf="mfDataTable"
         [mfRowsOnPage]="25" [(mfSortBy)]="sortBy" [(mfSortOrder)]="sortOrder">
           <thead>
               <tr>
                   <th class="v-align-middle" style="width:10%">
                        <mfDefaultSorter>Name</mfDefaultSorter>
                   </th>
                   <th class="v-align-middle" style="width:10%">
                           <mfDefaultSorter>Status</mfDefaultSorter>
                   </th>
                   <!-- <th class="v-align-middle" style="color: #369; width:10%;" data-hide="phone,tablet"> Action
                   </th> -->
               </tr>
           </thead>
           <tbody>
             <!-- <tr *ngFor="let user.referredUser.list[0] of mf.data; let i = index"> -->
             <tr>
                 <!-- <td class="v-align-middle"><span class="muted">
                 <img src="{{ helper.getImageUrl(appConfig, user) }}" class="list-logo">
                 {{ user?.referredUser?.list[0]?.name | titlecase }}</span></td> -->
                 <td class="v-align-middle"><span class="muted">
                 <input type="image" img src="{{ helper.getImageUrl(appConfig, user) }}" class="list-logo" data-toggle="tooltip" [routerLink]="['/user/' + user?.referredUser?.list[0]?.id + '/listdetail']"><br>
                 {{ user?.referredUser?.list[0]?.name | titlecase }}</span></td>
                 <td class="v-align-middle"><span class="muted"> {{ user?.referredUser?.list[0]?.status }} </span></td>
                 <!-- <td class="v-align-middle"><a class="muted" data-toggle="tooltip" [routerLink]="['/user/' + user?.referredUser?.list[0]?.id + '/listdetail']"><i
                   class="material-icons">border_color</i>
               </a></td> -->
             </tr>
             <!-- <tr *ngIf="!list || list.length <= 0">
                   <td colspan="4" align="center"> No data found. </td>
             </tr> -->
           </tbody>
            <tfoot>
             <tr>
               <td colspan="3">
                <mfBootstrapPaginator [rowsOnPageSet]="[10,25,50]"></mfBootstrapPaginator>
               </td>
             </tr>
           </tfoot>
        </table>

в настоящее время тот, который появляется, находится только в списке пользователей, который я написал в []

это мой JSON

{
  "status": true,
  "data": {
    "id": "-LhKgaOz90Rg21Y_PCxz",
    "address": [],
    "age": 23,
    "company": "",
    "createdAt": "2019-06-14T11:14:43.318Z",
    "referredBy": "",
    "referredUser": {
        "total": 5,
        "list": [
            {
                "id": "-LhidpFKI86szc92Tu_X",
                "name": "john",
                "status": "ACTIVE"
            },
            {
                "id": "-LhizE4bQiliDv_PjLxk",
                "name": "doe",
                "status": "ACTIVE"
            },
            {
                "id": "-LhkOpj5tDNhHeiCm4S8",
                "name": "jane",
                "status": "ACTIVE"
            },
            {
                "id": "-LhkQPJ5hhLJlsbtnpnr",
                "name": "doe",
                "status": "ACTIVE"
            },
            {
                "id": "-LhmZVyBWbC6ceERUdjC",
                "name": "frend",
                "status": "INACTIVE"
            }
        ]
    },
    "socialAbout": "-",
    "socialProfession": "Event organizer"
  }
}

это мой тс

    import { Component, OnInit } from '@angular/core';
import { ApiService } from '@service/api.service';
import { Helper } from '@common/helper';
import * as AppConfig from '../../../environments/AppConfig';

@Component({
  selector: 'app-influencerrank',
  templateUrl: './influencerrank.component.html',
  styleUrls: ['./influencerrank.component.css']
})
export class InfluencerrankComponent implements OnInit {

    constructor(public apiService: ApiService,
        public helper: Helper
    ) {
        this.appConfig = AppConfig;
    }
    public sortBy: 'createdAt';
    public sortOrder: 'desc';
    public appConfig: any;
    users: any;
    public mainUsers: any;

    ngOnInit() {
        this.apiService.postCall(this.apiService.usersList, { 'startFrom': '' }, (response) => {
            if (response.status === true) {
                this.mainUsers = response.data;
                this.users = response.data.filter((item: any) => item.userType === 'LEADER');
        });
            } 
        });
    }

}

1 Ответ

0 голосов
/ 20 июня 2019

Попробуйте это

<tr *ngFor="let user of mf.data.referredUser.list">
  <td>
    {{ user.name | titlecase }}
  </td>

  <td>
    {{ user.status }}
  </td>
</tr>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...