[英]angular $timeout redirect after 3secs
我正在尝试使用$ timeout和$ window.history.back()重定向回上一页。 因此,提交表单时会显示一条消息,表示(谢谢... bla bla)从此处一切正常,但是当重定向回$ timeout时似乎并没有生效。
<div class="thankyou" data-ng-show="vm.hideEnquiryForm">
<h3><i class="fa fa-envelope fa-x2"></i> Thank you for enquiring, we will get back to you as soon as possible.</h3>
<a href="javascript:history.back()">Return</a>
</div>
vm.submitForm = function () {
enquireService.postEnquireForm(vm)
.then(function (response) {
//$location.path(vm.returnUrl);
//console.log($location.path() + ' '+ vm.returnUrl);
if (!vm.hideEnquiryForm) {
vm.hideEnquiryForm = true;
}
$timeout(function () {
$window.history.back;
}, 3000);
})
}
有很多方法可以做您想要的...
我认为最好的方法可能是使用路由器公开的接口(假设您使用的是路由器)...
这是一个基于UI的有用文章。Router Angular-ui-router获得先前状态 ,因此,您只需要使用$state.go
进入先前状态$state.go
;
如果您不能做这样的事情,那么唯一的方法就是使用真实history
对象。
vm.submitForm = function () { var returnUrl; enquireService .postEnquireForm(vm) .then(function (response) { var returnUrl = response.returnUrl; if (!vm.hideEnquiryForm) { vm.hideEnquiryForm = true; } return $timeout(window.history.back.bind(window), 3000); }); };
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.