我有一个AngularJS单页面应用程序,显示3个视图(实际上是3 directives)。为了说明我的问题,让我们假设我的用户界面与GMail的用户界面相同,我的3个观点是:
这三个视图需要在路径更改时自行更新。例如:
在AngularJS中执行此操作的最佳方法是什么?
到目前为止,我有:
$routeProvider
仅支持一个ngView
。这种作品,但我有几个问题:
我需要注意路径更改的代码(我把它放在服务中或控制器中):
var watchExpression = function() { return $location.path(); };
var listener = function(newPath, oldPath) {
// Broadcast event on $rootScope
$rootScope.$broadcast('PathChanged', newPath);
};
$rootScope.$watch(watchExpression, listener);
然后,在视图控制器中,我捕获事件:
$scope.$on('PathChanged', function(event, path) {
// Update view based on new path.
});
任何帮助表示赞赏。感谢。
答案 0 :(得分:5)
您的最终版本似乎与locationChangeSuccess一样好,但是对于其他人来说,我认为你排除了$ routeProvider太快了。您可以为主内容窗格提供一个ng视图,该视图随路径一起更改,然后是导航窗格和工具栏的其他独立(“静态”)控制器/模板。
现在在其他2个控制器中监听路由更改:
$rootScope.$on('$routeChangeSuccess', function(evt, cur, prev) {
...do what you have to do here, maybe set a $rootScope.path as you did
})
全部使用原生Angular功能。我实际上是在http://provok.in,我使用Angular构建的网站中做到这一点,我有一个类似的布局(好吧,不完全是,但我有“静态”部分和主要内容的ng视图,基于动态更新在路径上,由routeProvider)。