![](/img/trans.png)
[英]Refresh browser page on browser back click when changing hash value in url
[英]Angular page refresh on changing URL parameter in browser
极其简单的要求,但是很难。 有一个简单的页面,我在其中在url路径中打印参数。
http://localhost:8888/ngtest.html#/1234567
ngtest.html
<div ng-app="app" ng-controller="testCtrl">
{{myId}}
</div>
<script>
var app = angular.module('app', []);
app.controller('testCtrl', function($scope, $location) {
$scope.myId = $location.$$path;
});
</script>
在浏览器窗口中:
1234567
更改为1234
什么都没发生。 按F5,它按预期工作。
不知道这是否与浏览器行为有关,但是如何在参数更改+ Enter之后强制页面刷新?
基于上述莱昂建议的完整示例
<script src="//ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.js"></script>
<div ng-app="app" ng-controller="testCtrl">
{{myId}}
</div>
<script>
var app = angular.module('app', []);
app.controller('testCtrl', function($scope, $location) {
// add a listener for when the url changes and user
// Enter in the address bar
$scope.$on('$locationChangeStart', function(event) {
$scope.myId = $location.$$path;
});
});
</script>
基本上,这是注册一个位置更改侦听器并相应地执行操作。 无需路由配置
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.