您的位置:首页 > Web前端 > JavaScript

window.location.reload与window.location.href

2015-10-21 22:39 525 查看
今天遇到一个bug。

问题描述

A页面和B页面只是页面状态不同,但是属于同一个url。

A页面有一个form表单,表单post提交之后,服务器会返回B页面,B页面会有一个ajax请求,ajax请求成功的回调函数callback中,会刷新当前页面。

问题就在于,在B页面的callback中使用window.location.reload()去刷新当前页面,那么在服务器端会收到A页面中的form表单的请求。

原因分析

因为从A页面到B页面是服务器端实现的跳转,浏览器没能察觉,因此依然缓存的是A页面,那么在B页面中使用window.location.reload进行刷新的时候,提交的依然是A页面。

解决方法

使用window.location.href=window.location.href,这种不是通过浏览器的刷新按钮去实现刷新的,而是通过替换url地址实现刷新的,这样相当于重新向服务器发了一次请求。相当于无缓存刷新。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  js-刷新页面