使用$ stateProvider的AngularJS/Ionic路由 - 控制器在第二次调用状态时不会重新加载

Wil*_*ris 5 javascript url-routing angularjs hybrid-mobile-app ionic-framework

原始问题

我正在开发一个使用Ionic Framework和AngularJS的移动应用程序,我遇到的问题是控制器在初始化后没有重新加载.

其中一个状态转换(从'app.postbox-details''app.audit-questions')应该将参数传递给'app.audit-questions'控制器,但是该控制器不会使用新参数更新自身,因为它没有重新加载.

代码示例

app.js文件 - 配置

angular.module('sf-maintenance', ['ionic', 'starter.controllers', 'starter.services', 'ngCordova'])           
.config(function ($stateProvider, $urlRouterProvider, $httpProvider) {
    $stateProvider
       .state('home', {
           url: '/home',
           templateUrl: 'templates/home.html',
           controller: 'HomeCtrl',
       })
       .state('app', { //app state being the side-menu
           url: '/app',
           abstract: true, //means that this state will never be activated directly, users will always go to a child state instead.
           templateUrl: 'templates/side-menu.html',
           controller: 'MenuCtrl'
       })       
       .state('app.postbox-details', {
           url: '/postbox-details',
           views: {
               'menuContent': {
                   templateUrl: 'templates/postbox-details.html',
                   controller: 'PostboxDetailsCtrl'
               }
           }
       })
    .state('app.audit-questions', {
        url: '/audit-questions/:postboxGuid',
        views: {
            'menuContent': {
                templateUrl: 'templates/audit-questions.html',
                controller: 'AuditCtrl'
            }
        }
    })
    $urlRouterProvider.otherwise('/home');
});
Run Code Online (Sandbox Code Playgroud)

controller.js文件(省略了不相关的代码)

angular.module('starter.controllers', [])    
.controller('HomeCtrl', function ($scope) {
})    
.controller('MenuCtrl', function ($scope) {
})    
.controller('PostboxDetailsCtrl', function ($scope, $ionicLoading, $ionicPopup, $cordovaBarcodeScanner, $state, DataService) {

    $scope.postboxGuid = DataService.getNewGUID();
    //Rest of the controller functions are below
})    
.controller('AuditCtrl', function ($scope, $ionicSlideBoxDelegate, $stateParams, DataService) {

    $scope.auditDetails = {
        postboxGuid: $stateParams.postboxGuid
    };    
});
Run Code Online (Sandbox Code Playgroud)

查看 - 导航代码

执行导航的视图代码全部使用<a>标记:

  • 从主视图到邮箱详细信息视图: <a class="button button-block button-dark icon-right ion-chevron-right" href="#/app/postbox-details">New inspection</a>
  • 从邮箱详细信息视图到审计问题视图: <a class="button button-block button-dark icon-right ion-chevron-right" ng-click="saveFormData()" ng-href="#/app/audit-questions/{{postboxGuid}}">New audit</a>

所以有人知道如何让控制器在初始化后重新加载,或者如果我正在解决这个问题,那么错误的方法可以指导我使用一种方法吗?


更新的信息

我最近看到了一个相关的问题,@RadimKöhler的回答指出了这个问题的答案,它提供了很好的信息,说明为什么cache:false因为性能而在视图上使用它可能不是一个好主意.

我想我会分享这个,因为在某些情况下,通过使用Ionic的内置视图生命周期事件之一 运行代码而不必禁用缓存视图,您可能会在性能方面获益更多.

小智 14

视图是标准缓存的离子.可以在视图或stateprovider中配置缓存.

http://ionicframework.com/docs/api/directive/ionNavView/