Angularjs   发布时间:2022-04-20  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了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,请注明来意。