gpt4 book ai didi

javascript - Angular ui 路由器 : stop controller from reloading on press of back button in the browser

转载 作者:数据小太阳 更新时间:2023-10-29 04:14:39 24 4
gpt4 key购买 nike

看起来,默认情况下,当您按下浏览器中的后退按钮转到上一个状态时,上一个状态的 Controller 会重新加载。(如果是父子状态则不是这样)

我怎样才能防止这种情况发生?

由于我不打算更改当前状态中的任何可能影响先前状态的数据,因此我不希望先前状态再次重新加载。

这是一个小笨蛋: http://plnkr.co/edit/xkQcEywRZVFmavW6eRGq?p=preview

有两种状态:homeabout。如果您转到 about 状态然后按返回按钮,您将看到再次调用 home 状态 Controller 。

.state('home', {
url: '/home',
templateUrl: 'partial-home.html',
controller: function($scope) {
console.log('i was called');
}
})

我相信这是预期的行为,但我想阻止它,因为我以前的状态(在本例中为 home)正在做一些可视化,需要一些时间才能再次创建。

最佳答案

让我们从一个像GlobalCtrl这样的全局 Controller 开始它被添加到 <body><html>标签如 ng-controller="GlobalCtrl .

这样做将使我们能够保持此 GlobalCtrl 的范围在你的单页 Angular 应用程序中(因为你正在使用 ui-router)。

现在,在你的 GlobalCtrl 中定义如下:

$rootScope.globalData = {preventExecution: false};

// This callback will be called everytime you change a page using ui-router state
$rootScope.$on('$stateChangeStart', function(event, toState, toParams, fromState) {
$scope.globalData.preventExecution = false;

// Just check for your states here
if (toState.name == "home" && fromState.name == "about") {
$scope.globalData.preventExecution = true;
}
});

现在,在您的状态配置中,您可以使用这个 $scope.globalData.preventExecution;

.state('home', {
url: '/home',
templateUrl: 'partial-home.html',
controller: function($scope) {
if ($scope.globalData.preventExecution) {
return;
}
console.log('i was called');
}
});

问题的答案:我们在 GlobalCtrl 中引用的范围和我们在 State Controller 中使用的范围,它们有什么关系?

好吧,这是一个非常好的问题,但它很简单。每次在 Angular 中创建新范围时,它总是继承其父范围(除非是隔离的)。所以当你的 home状态 Controller 已实例化,其范围使用父状态创建,即 $rootScope在这种情况下,我们正在实例化 globalData$rootScope这是一个对象(Javascript 中的 Object 可用于它是任何嵌套对象。 Read this )。所以现在当我们设置 globalData.preventExecutiontrue/false , 相同的数据可以用在 $scope 中你的home状态 Controller 。这就是两个范围相关或使用相同数据的方式。

问题的答案:ui-router 中是否有一些标志或设置通常可以完成此操作

如果你想为多个状态实现上面的行为代码那么你可以这样写:

$rootScope.$on('$stateChangeStart', function(event, toState, toParams, fromState) {
$scope.globalData.preventExecution = false;

if (toState.name == "home" && fromState && fromState.preventHomeReExecution) {
$scope.globalData.preventExecution = true;
}
});

现在,你的状态可以这样写:

.state('about', {
url: '/about',
templateUrl: 'partial-about.html',
preventHomeReExecution: true
})
.state('foo', {
url: '/foo',
templateUrl: 'partial-foo.html',
})
.state('bar', {
url: '/bar',
templateUrl: 'partial-bar.html'
preventHomeReExecution: true
})

基本上,我们使用 preventHomeReExecution: true作为你想要的旗帜。

关于javascript - Angular ui 路由器 : stop controller from reloading on press of back button in the browser,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34354502/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com