加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

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;         
    }

变得丑陋…

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读