Привет! Я пытаюсь передать данные от родителя к потомку к его дочернему компоненту. От родителя к потомку работает нормально, но от потомка к его потомку ничего не отображается (пользовательский интерфейс не обновлен?).
Ионная родительская страница (comments.ts):
...
export class CommentsPage {
selectedFeedPost: FeedPostModel
selectedGroupId: string
commentsList: CommentModel[]
constructor(private _viewCtrl: ViewController, public navCtrl: NavController, public navParams: NavParams) {
}
ionViewDidLoad() {
if (this.navParams.data && this.navParams.data.feedPost && this.navParams.data.groupId) {
this.selectedFeedPost = this.navParams.data.feedPost
this.selectedGroupId = this.navParams.data.groupId
// The rest will be handled in the custom comments components
this.commentsList = this.selectedFeedPost.comments // Don't have to check again, should only be able to access when feed post has comments.
}
}
}
Ионный просмотр страницы (comments.html):
...
<ion-content padding>
<!-- Custom component for holding comments, passing an array of comments to child component -->
<comments-list *ngIf="commentsList" [commentsList]="commentsList"></comments-list>
</ion-content>
...
Дочерний пользовательский компонент (comments-list.ts):
@Component({
selector: 'comments-list',
templateUrl: 'comments-list.html',
inputs: ['commentsList']
})
export class CommentsListComponent implements OnInit {
// Used to capture the passed through data from a parent component.
commentsList: CommentModel[]
// Used to bind to the UI
displayList: CommentModel[] = []
constructor() {}
ngOnInit() {
// Component initialization function, first function to be triggered when component is called/loaded/entered.
// Transform [Object object] to Array of objects, for binding
for (let i in this.commentsList) {
this.displayList.push(this.commentsList[i])
}
}
}
Дочерний пользовательский компонент HTML (comments-list.html):
<ion-list>
<ion-item-sliding #itemSlide *ngFor="let comment of displayList">
<!-- Custom component -->
<comment-thumbnail [comment]="comment"></comment-thumbnail>
<ion-item-options>
<button ion-button color="primary">
<ion-icon name="alert"></ion-icon>
Report
</button>
<button ion-button color="danger">
<ion-icon name="trash"></ion-icon>
Delete
</button>
</ion-item-options>
</ion-item-sliding>
</ion-list>
* Пока здесь все работает нормально. *
Дочерний объект дочернего вида не отображает ничего, пока есть данные.
Дочерний элемент дочернего пользовательского компонента (comment-thumbnail.ts):
import { Component, OnInit, OnChanges, Input } from '@angular/core';
/* Models & interfaces */
import { CommentModel } from '../../models/comment.model';
@Component({
selector: 'comment-thumbnail',
templateUrl: 'comment-thumbnail.html',
inputs: ['comment']
})
export class CommentThumbnailComponent implements OnInit, OnChanges {
// Used to capture the passed through data from a parent component.
@Input() comment: CommentModel
item: CommentModel
constructor() {}
ngOnInit() {
console.log(this.comment)
this.item = this.comment
}
ngOnChanges() {
console.log(this.comment)
this.item = this.comment
}
}
Дочерний вид дочернего пользовательского компонента (comment-thumbnail.html):
<ion-item>
<ion-avatar item-start>
<img src="{{ item.created.by.photoUri }}">
</ion-avatar>
<h2>{{ item.created.by.name }}</h2>
<p>{{ item.message }}</p>
<ion-note item-end>
{{ item.created.at * 1000 | date:'MMM d, y, h:mm a' }}
</ion-note>
</ion-item>
Выход консоли Chrome:
Ничего не отображается в представлении, но данные регистрируются в консоли. Есть идеи?