S
S
Speakermen2021-11-28 19:34:42
typescript
Speakermen, 2021-11-28 19:34:42

Why is Type 'Album' is missing the following properties from type 'Album[]': length, pop, push, concat, and 28 more?

//child
import { Component, Input, OnInit } from '@angular/core';
import { Album } from '../../models/album';

@Component({
  selector: 'app-album-item',
  templateUrl: './album-item.component.html',
  styleUrls: ['./album-item.component.css'],
})
export class AlbumItemComponent implements OnInit {
  //@Input() public album: any;
  @Input() public album: Album[];

  constructor() {
    this.album = [];
  }

  ngOnInit(): void {
    console.log(this.album);
  }
}


export interface Album {
  album_image: string;
  album_count: number;
  album_title: string;
}


<div class="wm-main-content">
  <div class="wm-main-section">
    <div class="container">
      <div class="row">
        <div class="col-md-12">
          <div class="wm-latestartist-album wm-albummasonry-list">
            <ul class="row">
              <div *ngFor="let album of albums">
                <app-album-item [album]="album"></app-album-item>
              </div>
            </ul>
          </div>
          <app-pagination></app-pagination>
        </div>
      </div>
    </div>
  </div>
</div>


//parent
import { Component, OnInit } from '@angular/core';
import { Album } from '../../models/album';

@Component({
  selector: 'app-album',
  templateUrl: './album.component.html',
  styleUrls: ['./album.component.css'],
})
export class AlbumComponent implements OnInit {
  public albums: Album[];

  constructor() {
    this.albums = [];
  }

  ngOnInit(): void {
    this.albums = [
      {
        album_image: '/assets/extra-images/latest-album-1.jpg',
        album_count: 3,
        album_title: 'album_title1',
      },
      {
        album_image: '/assets/extra-images/latest-album-2.jpg',
        album_count: 4,
        album_title: 'album_title2',
      },
      {
        album_image: '/assets/extra-images/latest-album-3.jpg',
        album_count: 2,
        album_title: 'album_title2',
      },
      {
        album_image: '/assets/extra-images/latest-album-4.jpg',
        album_count: 3,
        album_title: 'album_title2',
      },
      {
        album_image: '/assets/extra-images/latest-album-1.jpg',
        album_count: 3,
        album_title: 'album_title1',
      },
      {
        album_image: '/assets/extra-images/latest-album-2.jpg',
        album_count: 4,
        album_title: 'album_title2',
      },
      {
        album_image: '/assets/extra-images/latest-album-3.jpg',
        album_count: 2,
        album_title: 'album_title2',
      },
      {
        album_image: '/assets/extra-images/latest-album-4.jpg',
        album_count: 3,
        album_title: 'album_title2',
      },
    ];
  }
}

Answer the question

In order to leave comments, you need to log in

1 answer(s)
D
Dmitry Belyaev, 2021-11-28
@Speakermen

Here you write that you expect an array from Album:

export class AlbumItemComponent implements OnInit {
  //@Input() public album: any;
  @Input() public album: Album[];

And here you pass the Album objects one by one:
<div *ngFor="let album of albums">
  <app-album-item [album]="album"></app-album-item>
</div>

Didn't find what you were looking for?

Ask your question

Ask a Question

731 491 924 answers to any question