【发布时间】:2018-02-04 11:29:39
【问题描述】:
每个选项卡使用不同的 navParams 调用相同的组件“EventDetailItemsComponent”。并且从 this.itemService 中检索异步数据(Observable)并按预期显示。
当我第二次切换回同一个标签时,问题就开始了。由于不再调用 Component,因此它显示相同的异步数据。所以标签视图没有更新。
我想要的是每次单击选项卡时调用 EventDetailItemsComponent 。不仅仅是第一次点击。
使用 (ionSelect)="myMethod()" 将异步数据从父组件 EventDetailComponent 传递到子组件 EventDetailItemsComponent 是否正确?
<ion-tabs no-margin no-padding selectedIndex="1">
<ion-tab [root]="EventDetailItems1" [rootParams]="{itemTypeId:1, eventId: (eventDetail | async)?.id}" tabTitle="{{'ALL' | translate}}"></ion-tab>
<ion-tab [root]="EventDetailItems2" [rootParams]="{itemTypeId:2, eventId: (eventDetail | async)?.id}" tabTitle="{{'BOUGHT' | translate}}"></ion-tab>
<ion-tab [root]="EventDetailItems3" [rootParams]="{itemTypeId:3, eventId: (eventDetail | async)?.id}" tabTitle="{{'LEFT' | translate}}"></ion-tab>
</ion-tabs>
export class EventDetailComponent implements OnInit {
EventDetailItems1: any = EventDetailItemsComponent;
EventDetailItems2: any = EventDetailItemsComponent;
EventDetailItems3: any = EventDetailItemsComponent;
constructor(){ }
}
子组件EventDetailItemsComponent及其html
@Component({
selector: 'event-detail-items',
styleUrls: ['/event-detail-items.scss'],
templateUrl: 'event-detail-items.html'
})
export class EventDetailItemsComponent implements OnInit, OnChanges {
private _itemDetail = new BehaviorSubject<ItemViewModel[]>(null);
itemDetail = this._itemDetail.asObservable();
itemToggle: number = 0;
lastImage: string = null;
loading: Loading;
constructor(
public itemService: ItemService,
public eventService: EventService,
public navParams: NavParams,
public navCtrl: NavController,
public loadingCtrl: LoadingController,
private app: App) {
}
ngOnInit() {
let itemParams: GiftItemTabNavParams = JSON.parse(JSON.stringify(this.navParams.data));
this.itemService.getItemList(itemParams.eventId, itemParams.itemTypeId).subscribe(x => {
this._itemDetail.next(x);
});
}
}
<ion-grid id="gift-list-grid">
<ion-row class="gift-list-row" *ngFor="let giftItem of (itemDetail | async)" text-center bottom>
<ion-col (click)="toggleItemDescription(giftItem.id)" class="gift-item-col-item-pic" col-3>
<img src="{{giftItem.giftImagePath}}" />
</ion-col>
<ion-col (click)="toggleItemDescription(giftItem.id)" class="gift-item-col-detail" col-6>
<ion-label text-wrap class="gift-item-text" no-margin text-left>
<span>
{{giftItem.giftItemName}}
</span>
<span>
{{giftItem.brand}}
</span>
</ion-label>
</ion-col>
<ion-col (click)="toggleItemDescription(giftItem.id)" class="gift-item-col-gift-count" col-3>
<img src="./assets/img/inner-pages/gift_box.png" />
<p>
{{giftItem.amount}}
</p>
</ion-col>
<ion-col (click)="toggleItemDescription(giftItem.id)" *ngIf="itemToggle == giftItem.id" col-9>
<ion-label text-wrap class="gift-item-description" no-margin text-left>
<span>
{{giftItem.amount}} {{'AMOUNT' | translate}}
</span>
<span>
{{giftItem.description}}
</span>
</ion-label>
</ion-col>
<ion-col (click)="toggleBuyStatus(giftItem.id, giftItem.isBought, giftItem.giftStatus)" *ngIf="itemToggle == giftItem.id" class="gift-item-col-detail" col-3>
<!--RESERVABLE ITEM-->
<img *ngIf="giftItem.giftStatus == 0" src="./assets/img/inner-pages/free.png" />
<!--CAN BE UNRESERVED-->
<img *ngIf="giftItem.giftStatus == 1" src="./assets/img/inner-pages/unreservable.png" />
<!--CAN NOT BE UNRESERVED-->
<img *ngIf="giftItem.giftStatus == 2" src="./assets/img/inner-pages/not-unreservable.png" />
</ion-col>
</ion-row>
</ion-grid>
更新:正如 Sampath 所说,Events 解决了这个问题。您可以在下面找到用法:
根 EventDetailComponent - 事件发布:
public eventTabsChanged(itemTypeId) {
let event = this._eventDetail.getValue();
this.events.publish('tab:clicked', itemTypeId, event.id);
}
标签内容EventDetailItemsComponent - 事件订阅
constructor(
public itemService: ItemService,
public events: Events) {
events.subscribe('tab:clicked', (itemTypeId, eventId) => {
this.itemService.getItemList(eventId, itemTypeId).subscribe(x => {
this._itemDetail.next(x);
});
});
}
【问题讨论】:
-
你也可以显示子组件的
code吗?html和ts. -
@Sampath 我添加了子组件及其 html
-
ion-tab 或 ion-grid 点击你想更新?
-
@rashidnk 您是否建议使用单击并在函数内部使用@Input 将异步数据传递给子组件?
-
可以展示一下亲子互动的
code吗?html代码?
标签: angular typescript ionic2 ionic3