AngularJS:更改哈希和路由,而不完全重新加载控制器
发布时间:2020-12-17 08:39:52 所属栏目:安全 来源:网络整理
导读:我有一个控制器,具有这样的路线: #/ articles / 1234 我想改变路线而不完全重新加载控制器,所以我可以保持其他东西在控制器中的位置不变(列表滚动) 我可以想到几种方法来做到这一点,但他们都很丑陋。有这样做的最佳做法吗?我试着用reloadOnSearch:fals
我有一个控制器,具有这样的路线:
#/ articles / 1234 我想改变路线而不完全重新加载控制器,所以我可以保持其他东西在控制器中的位置不变(列表滚动) 我可以想到几种方法来做到这一点,但他们都很丑陋。有这样做的最佳做法吗?我试着用reloadOnSearch:false,但它似乎没有改变任何东西。
有同样的挑战,
在another StackOverflow response发现了一个黑客做了伎俩 相当干净的解决方案 – 我做的只是添加这些行到控制器设置$ location.path: var lastRoute = $route.current; $scope.$on('$locationChangeSuccess',function(event) { $route.current = lastRoute; }); ..并确保$ route注入到控制器当然。 但仍然,感觉像“DoNotFollowRoutesOnPathChange”是AngularJS中缺少的功能。 / Jens 更新:因为监听这个事件有效地杀死了$ routeProvider配置的进一步使用,我不得不限制这个catch到当前路径: var lastRoute = $route.current; if ($route.current.$route.templateUrl.indexOf('mycurrentpath') > 0) { $route.current = lastRoute; } 变得丑陋… (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |