我有一个场景,我的网页中有 3 个选项卡,其中在选项卡内容区域中,每个选项卡激活时会加载三个不同的组件(比如组件“ABC”、“PQR”、“XYZ”)。在存在选项卡的主页中,我必须显示一些与选项卡中加载的选项卡内容相关的标题数据。假设如果BAC
加载了选项卡,我必须显示从ABC
组件发送的一些消息,对于所有三个组件也是如此。
我尝试使用单个组件,但我的事件侦听器无法正常工作。
主选项卡页面(父组件): HTML 文件tabs.component.html:
<h1>{{headerMessage}}</h1>
<my-tabs [items]="tabItems">
<router-outlet (tabHeaderTextEvent)="receiveHeaderText($event)"></router-outlet>
</my-tabs>
tabs.component.ts:
import { Component, OnInit } from '@angular/core';
import { TabItem } from '@MYCOMPONENTS/tabs';
@Component({
selector: 'MYPAGE-tabs',
templateUrl: './tabs.component.html',
styleUrls: ['./tabs.component.scss']
})
export class TabsComponent implements OnInit {
public headerMessage: String;
public tabItems: TabItem[] = [];
constructor(private authService: AuthService) {
this.tabItems = [{
routerPath: 'abc',
label: 'ABC_LABEL',
}, {
routerPath: 'PQR',
label: 'PQR_LABEL',
disabled: true
},
{
routerPath: 'XYZ',
label: 'XYZ_LABEL',
disabled: true
}];
}
receiveHeaderText($event) {
console.log('***********************************');
console.log($event);
this.headerMessage = $event;
}
}
Child.component.ts(我希望从那里发送数据):
import { Component, OnInit, Output, EventEmitter } from '@angular/core';
import { Router, ActivatedRoute } from '@angular/router';
@Component({
selector: 'someSelector',
templateUrl: './sometemplate.component.html'
})
export class Child implements OnInit {
@Output() tabHeaderTextEvent = new EventEmitter<string>();
constructor() {
this.tabHeaderTextEvent.emit('hello from overview component');
}
}
同样,我还有两个组件tabHeaderTextEvent
在其构造函数调用上发出事件。但是我的选项卡组件中的侦听器函数永远不会被调用。谁能指导我哪里出错了?
或
任何更好的方法来实现相同的目标。提前致谢。