使用this.navCtrl.push(NamePage);
我不明白,我需要使用@ViewChild
或其他功能吗?
我在 app.module.ts
tabsHideOnSubPages
上设置了false
示例:https://github.com/Nicolas-PL/TestMenu
文件是:src/pages/tabs/tabs.ts
和src/pages/test/test.ts
import { Component } from '@angular/core';
import { NavController } from 'ionic-angular';
import { AboutPage } from '../about/about';
import { ContactPage } from '../contact/contact';
import { HomePage } from '../home/home';
import { TestPage } from '../test/test';
import { ModalController } from 'ionic-angular';
@Component({
templateUrl: 'tabs.html'
})
export class TabsPage {
tab1Root = HomePage;
tab2Root = AboutPage;
tab3Root = TestPage;
constructor(public navCtrl: NavController,public modalCtrl: ModalController) {
}
openModal() {
let myModal = this.modalCtrl.create(TestPage);
myModal.present();
}
}
<ion-tabs>
<ion-tab [root]="tab1Root" tabTitle="Home" tabIcon="home"></ion-tab>
<ion-tab [root]="tab2Root" tabTitle="About" tabIcon="information-circle"></ion-tab>
<ion-tab (ionSelect)="openModal()" tabTitle="Contact" tabIcon="contacts"></ion-tab>
</ion-tabs>
Test.ts(标签消失)
import { Component } from '@angular/core';
import { IonicPage, NavController, NavParams } from 'ionic-angular';
import { HomePage } from '../home/home';
import { App, ViewController } from 'ionic-angular';
@IonicPage()
@Component({
selector: 'page-test',
templateUrl: 'test.html',
})
export class TestPage {
constructor(public viewCtrl: ViewController, public navCtrl: NavController, public navParams: NavParams) {}
ionViewDidLoad() {}
openMenu() {
this.navCtrl.push(HomePage);
}
}
我试过this.navCtrl.root(HomePage);
但是没有用..
提前谢谢!
答案 0 :(得分:1)
如果您需要从overlay
组件(popover
,modal
,alert
等)进行导航,那么您必须按照以下方式进行操作。
test.ts
export class TestPage {
constructor(
public viewCtrl: ViewController
public appCtrl: App
) {}
openMenu() {
this.viewCtrl.dismiss();
this.appCtrl.getRootNav().setRoot(HomePage);
}
}
您可以详细了解it here(请参阅标题Navigating from an Overlay Component
)。
答案 1 :(得分:0)
我刚刚找到了解决方法。
如果从不在选项卡中的页面调用push(),则选项卡消失。 所以,我叫一个事件
options: HttpClient['post']['options']
然后,我导航到我的根选项卡
this.events.publish('gotochat', { item: element });
在登录页面中,我听事件并推送所需的页面。
this.nav.setRoot('TabsPage', { index: 1 }, {
animate: true,
direction: 'forward'
});