我使用$state.go();来切换页面
其中有些页面的数据是动态的,我希望每次进来都重新加载数据。
请问如何每次当切换到这个页面时都重新加载页面(重新执行controller中的方法)?
PS:
$state.go('page',null,{
reload:true
});
这个也并没有效果
app.run(['$rootScope', '$location',
function($rootScope, $location) {
$rootScope.$on('$stateChangeStart', function(evt, next, current) {
alert('route begin change');
});
}
]);
我在这里获得了state变化的事件 然而并不知道如何刷新$scope...
PS2:
我是这样实现的
$scope.$on('$stateChangeSuccess', function(evt, next, current) {
// 数据reload
});
不知道算不算土办法...
但是这样也出现一个新的问题
$stateChangeSuccess中的方法会触发2遍,这是什么情况呢?
Vous pouvez enregistrer des données dans sessionStorage. Puis diffusez lors de l'événement d'écoute de $on ci-dessous. Écoutez ensuite cet événement de diffusion dans le contrôleur de sous-couche.
Aucun traitement particulier n'est requis. Le code que vous écrivez dans le contrôleur sera automatiquement exécuté à chaque fois que vous basculerez sur cette page
Le contrôleur générera une nouvelle instance à chaque fois. Chaque fois que l'état change, le contrôleur et la vue sont de nouvelles instances. Ceci est également cohérent avec l'idée d'injection d'angularjs. Vous pouvez l'enregistrer vous-même dans le code du contrôleur.
"La méthode dans $stateChangeSuccess sera déclenchée deux fois" C'est parce que vous avez écrit les informations du contrôleur à la fois dans la vue et dans la route