我使用 routeProvider 为我的 url 定义控制器和模板。
当我单击与实际位置具有相同 url 的链接时,没有任何反应。reload()
如果用户点击这样的链接,即使位置没有改变,我也希望调用该方法。换句话说,如果我将位置设置为相同的值,我希望它的行为与将其设置为不同的值一样。
有没有办法配置 routeProvider 或 locationProvider 自动完成?或者这样做的正确方法是什么?这是往返应用程序中的标准行为,但是如何在 angularjs 中做到这一点?
我也在谷歌群组上问过。
更新:
这个问题得到了很多意见,所以我将尝试解释我是如何解决我的问题的。
正如 Renan Tomal Fernandes 在评论中建议的那样,我创建了一个自定义指令,用于在我的应用程序中进行链接。
angular.module('core.directives').directive('diHref', ['$location', '$route',
function($location, $route) {
return function(scope, element, attrs) {
scope.$watch('diHref', function() {
if(attrs.diHref) {
element.attr('href', attrs.diHref);
element.bind('click', function(event) {
scope.$apply(function(){
if($location.path() == attrs.diHref) $route.reload();
});
});
}
});
}
}]);
然后将该指令用于我想要具有此功能的应用程序中的所有链接。
<a di-href="/home/">Home</a>
该指令的作用是它根据href
属性为您设置属性,di-href
因此 Angular 可以像往常一样处理它,当您将鼠标悬停在链接上时,您可以看到 url。此外,当用户单击它并且链接的路径与当前路径相同时,它会重新加载路由。