首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在angular 2中如何在组件初始化后调用组件

在angular 2中如何在组件初始化后调用组件
EN

Stack Overflow用户
提问于 2017-11-20 16:44:15
回答 2查看 1.3K关注 0票数 0

有没有办法在其他组件完成初始化后对其进行初始化?

我的情况是,我有一个完整的日历,当它完成初始化时,一个新的组件需要开始初始化,因为他需要日历中的数据。那么,是否有可能在第一个组件的初始化完成时捕获,以便开始第二个组件的初始化?

目前这两个组件一起启动,如果第二个组件先完成,我遇到了问题,它没有显示需要从第一个组件获取的信息

主要组件html:

代码语言:javascript
复制
<app-calendar-component [view]="calView" [callback]="calendarOptions" >
</app-calendar-component>
<app-weekdetails-component></app-weekdetails-component>

完整日历组件(需要初始化的第一个组件):

代码语言:javascript
复制
ngOnInit(){
this.service.getTimes<any>(arg).subscribe((data:string)=> this.result = JSON.stringify(data),
        error => () => {
            console.log("error");
        },
        () => {
//data actions
this.my_events.events = dataArray;
            this.myCalendar.fullCalendar('addEventSource', this.my_events);
}
}

weekDetailsComponent (第二个组件):

在这里调用另一个服务来获取包含在每一天中的数据,这个组件需要在完整日历完成后启动它的初始化。

EN

回答 2

Stack Overflow用户

发布于 2017-11-20 17:18:11

试试这个:

TS:

代码语言:javascript
复制
showCalendar:boolean = false;
ngOnInit(){
this.service.getTimes<any>(arg).subscribe((data:string)=> this.result = JSON.stringify(data),
        error => () => {
            console.log("error");
        },
        () => {
//data actions
this.my_events.events = dataArray;
            this.myCalendar.fullCalendar('addEventSource', this.my_events);
            this.showCalendar = true;
}
}

HTML:

代码语言:javascript
复制
<app-calendar-component [view]="calView" [callback]="calendarOptions" >
</app-calendar-component>
<app-weekdetails-component *ngIf="showCalendar"></app-weekdetails-component>

{{showCalendar}}

票数 0
EN

Stack Overflow用户

发布于 2017-11-20 17:21:37

您可以定义一个初始化为false的私有布尔属性,例如private isInit: boolean = false;。在回调中,您可以在日历回调中将此属性设置为true。在html中,您必须添加到第二个组件*ngIf=“isInit”中。

希望能有所帮助

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47388009

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档