我正在尝试做一个简单的应用程序,底部有三个选项卡,并且所有三个选项卡都有一个设置图标.当您单击该图标时,应该隐藏选项卡并显示设置屏幕.
由于我不希望用户丢失任何内容,因此所有视图都从全局视图继承:
- angular.module('app',['ionic','debug']).config(function($stateProvider,$urlRouterProvider) {
- $stateProvider
- .state('app',{
- url: "/app",abstract: true,controller: 'AppController',templateUrl: "ui/modules/tabs/view.html"
- })
- .state('app.compose-text',{
- url: '/text',views: {
- 'compose-text': {
- templateUrl: 'ui/modules/text-composer/view.html'
- }
- }
- })
- .state('app.compose-draw',{
- url: '/draw',views: {
- 'compose-draw': {
- templateUrl: 'ui/modules/draw-composer/view.html'
- }
- }
- })
- .state('app.compose-photo',{
- url: '/photo',views: {
- 'compose-photo': {
- templateUrl: 'ui/modules/photo-composer/view.html'
- }
- }
- })
- .state('app.settings',{
- url: '/settings',views: {
- 'settings': {
- controller: 'ui/modules/settings/ctrl.js',templateUrl: 'ui/modules/settings/view.html'
- }
- }
- });
- // if none of the above states are matched,use this as the fallback
- $urlRouterProvider.otherwise('/app/text');
- });
- angular.module('app').run(function($rootScope) {
- });
然后,tabs / view看起来像这样:
- <ion-nav-view name="settings"></ion-nav-view>
- <ion-tabs class="tabs-assertive tabs-icon-only">
- <ion-tab title="Text" icon="icon ion-ios7-compose-outline" href="#/app/text">
- <ion-nav-view name="compose-text"></ion-nav-view>
- </ion-tab>
- <ion-tab title="Draw" icon="icon ion-edit" href="#/app/draw">
- <ion-nav-view name="compose-draw"></ion-nav-view>
- </ion-tab>
- <ion-tab title="Photo" icon="icon ion-ios7-camera-outline" href="#/app/photo">
- <ion-nav-view name="compose-photo"></ion-nav-view>
- </ion-tab>
- </ion-tabs>
其中一个观点:
- <ion-view title="Example" class="slide-left-right">
- <ion-nav-buttons side="left">
- <a class="button button-icon button-clear ion-ios7-gear-outline" href="#/app/settings"></a>
- </ion-nav-buttons>
- <ion-content padding="true">
- <h1>Text</h1>
- </ion-content>
- </ion-view>
我想知道的第一件事是:有没有办法在所有视图之间重用这些按钮?似乎无用于一遍又一遍地定义它们.
但这不是真实的东西.当我点击“设置”时,会有一些东西被注入到离子导航视图中,但是它包含很多东西(不在模板上),而且它不会隐藏其他视图和标签.
一些截图:
http://forum.ionicframework.com/uploads/default/_optimized/410/778/37f711d3f9_312x500.png
应该采用什么方法?
要导航到没有标签栏的视图:
从设置状态中删除“app”前缀,因此它不再是父抽象状态(app)的子项.
- .state('settings',templateUrl: 'ui/modules/settings/view.html'
- }
- }
- });
**如果在此之后添加任何状态,请务必删除分号,而分号表示结束.
这是一个助听解决方案.
您的问题的完整解决方案是从离子项目模板开始.幸运的是,他们有一个标签选项,这是一个全局标签栏.
命令行:
离子启动appName选项卡
这应该为您提供适当的起始模板,包含您需要的一切.它还有示例controllers.js,services.js和app.js文件,因此您可以从那里构建.它还可以帮助您正确构建项目,以防止意外数据注入您的标记.
来源1:http://ionicframework.com/getting-started/
来源2:http://ionicframework.com/docs/api/directive/ionNavView/
**奖励:源2中还有一个巧妙的技巧,它向您展示如何将所有模板保留在index.html文件中,以加快应用程序并简化您的工作流程.
祝好运.