大佬教程收集整理的这篇文章主要介绍了AngularJS:更改哈希和路由,而不完全重新加载控制器,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
#/ articles / 1234
我想改变路线而不完全重新加载控制器,@R_237_9447@保持其他东西在控制器中的位置不变(列表滚动)
我可以想到几种方法来做到这一点,但他们都很丑陋。有这样做的最佳做法吗?我试着用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; }
变得丑陋…
以上是大佬教程为你收集整理的AngularJS:更改哈希和路由,而不完全重新加载控制器全部内容,希望文章能够帮你解决AngularJS:更改哈希和路由,而不完全重新加载控制器所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。