根据我对Ionic文档和问题的理解,例如: How to keep tab when pushing a new page?
我已正确完成了阻止我的标签栏被隐藏的必要条件。要清楚,标签栏正确显示何时在任何标签页上开始导航,然后转到堆栈中的任何其他标签页。每当你使用"推"来自导航控制器或模态控制器等的方法,标签栏消失。我哪里错了?
在下面的代码中,当第一次下载应用时,此人登陆演练。有一个按钮,然后将它们带到标签栏也应该是的目录。
在用户已经看过演练的情况下,根页面设置为主页,其中存在标签栏。如果用户使用标签栏从主页导航到目录页面,则标签栏会保留在页面底部的正确位置。
根据我的理解,将appHideOnSubPages:false添加到app.module.ts会阻止此行为,但事实并非如此。
app.module.ts ...
imports: [
IonicModule.forRoot(MyApp, {
tabsHideOnSubPages:false
})
]
...
app.component.ts ...
import { Tabs } from '../pages/tabs/tabs';
import { Walkthrough } from '../pages/walkthrough/walkthrough';
@Component({
templateUrl: 'app.html'
})
export class MyApp {
rootPage: any = Tabs;
launchObject:any;
constructor(private platform: Platform){
platform.ready().then(() => {
if(justDownloadedApp){
this.rootPage = Walkthrough;
}
})
}
}
...
app.component.html
<ion-nav [root]="rootPage"></ion-nav>
tabs.ts
import { Component } from '@angular/core';
import { Home } from '../home/home';
import { Directory } from '../directory/directory';
@Component({
templateUrl: 'tabs.html'
})
export class Tabs {
tab1Root: any = Home;
tab2Root: any = Directory;
constructor(){}
}
tabs.html
<ion-tabs>
<ion-tab [root]="tab1Root" tabsHideOnSubPages="false" tabTitle="Spotlight" tabIcon="flash"></ion-tab>
<ion-tab [root]="tab2Root" tabsHideOnSubPages="false" tabTitle="Stores" tabIcon="cart"></ion-tab>
</ion-tabs>
walkthrough.ts
import { Component } from '@angular/core';
import { NavController } from 'ionic-angular';
import { Directory } from '../directory/directory';
@Component({
selector: 'walkthrough',
templateUrl: 'walkthrough.html'
})
export class Walkthrough {
constructor(public navCtrl: NavController){}
toDirectory(): any{
this.navCtrl.push(Directory);
}
}
walkthrough.html
<ion-header class="opaque"></ion-header>
<ion-content class="walkthroughBackground">
<ion-col>
<ion-row>
<button class="clear-button-two" (click)="toDirectory()">Directory</button>
</ion-row>
<ion-col>
</ion-content>
答案 0 :(得分:10)
这是预期的行为。 tabsHideOnSubPages:false
是默认行为。这不是问题。当this.navCtrl.push(Directory);
它出现在WalkThrough
组件之上时。 Directory
不知道标签。
只有Tabs
页面及其子页面才会知道标签。您尚未将Tabs
推入NavController
。因此导航数组看起来像[WalkThrough,Directory]
。相反,您需要[WalkThrough, Tabs(default: Directory)]
。
您需要推送标签页并设置<ion-tabs selectedIndex="1">
。您可以使用navParams
来传递需要选择的索引。这是一个模拟。
walkthrough.ts
- &GT; this.navCtrl.push(Tabs,{index: "1"});
tabs.ts - &gt; index = navParams.get('index')
tabs.html - &gt; <ion-tabs selectedIndex= {{index}} >
我没有测试过它。希望它适合你。