как извлечь данные из вложенного объекта Json в angular4-Ngrx-lodash - PullRequest
0 голосов
/ 09 июня 2018

Я пытаюсь отобразить имена выпадающих элементов и могу получить только name , но хочу показать editorName из вложенного объекта. Я пытался использовать loadsh, forEach, но не смогдля отображения. Я новичок в ngrx.

HTML:

<div class="dopdown" *ngFor='let item of items$ |async'>
<a href="">{{item.name}}</a></div

ОТВЕТ API:

[{
"grpId": 1,
"name": "brain editor",
"member": {
    "gif1": {
        "gpId": "gp1",
        "firstName": "Danny",
        "lastName": "Johns",
        "editorName": "Danny-Johns",
        "suffix": "JR.",
        "Add": true
    },
    "gif2": {
        "gpId": "gp2",
        "firstName": "Mary",
        "lastName": "chang",
        "editorName": "Mary-chang",
        "suffix": "JR.",
        "Added": true
    }
},
"numbers": {
    "a01": {
        "numbersId": "a1",
        "numbersShow": "Dnn1093746",
        "numbersTo": ["gf1", "gf4"],
    }
}}]

angular.service.ts

  export class NewService {
     private _myUrl = 'http://myJsonApi';
   constructor(private _http: HttpClient) {}

      getData(): Observable<Idata[]>{
              return this._http.get<Idata[]>(this._myUrl)
              .pipe(
                      tap(data => {}),
                     catch(this.handleError)) }     
   private handleError(err : HttpErrorResponse){   
                 return Observable.throw(err.message);}}

Component.ts:

 export class NewClass implements OnInit {
   vm: any = {};
   items$: Observable<Idata[]>

   constructor(private store: store<fromRoot.AppState>) {}

      ngOnInit(): void {
              this.items$ = this.store.select(fromRoot.getNameDrpdwn)
              getData(); 
       }
       getData() {
              this.store.dispatch(new nameAction.LoadNameAction());    
       }}

Model.ts

export interface Idata {
              grpId: number;
              name: string;
            member: any;
          editorName: string;
     }

1 Ответ

0 голосов
/ 09 июня 2018

Попробуйте этот оператор интерполяции

{{ item.member.gif1.firstName }}

вместо

{{item.name}}

РЕДАКТИРОВАТЬ

<div class="dopdown" *ngFor='let item of items$ | async'>
    <a href="">{{item.member.gif1.editorName}}</a>
    <a href="">{{item.member.gif2.editorName}}</a> 
</div>
...