JS 返回上一页并刷新,但不用重新加载整个页面(ajax实现)
需求
有三个页面A、B、C,点击A=>B,点击B=>C,在C中添加内容,点击确定返回到B,此时B页面需重新加载新的内容。再次点击B的返回按钮,希望返回到A而不是C。
===== 2017/5/10 更新 ======
IOS 浏览器的诡异表现:history.go(-1)返回上一页后,页面内容并不会刷新。在C页面添加的内容,返回到B时并没有更新新的内容,必须手动刷新。
经过debug,发现在ios浏览器中,返回上一页后,页面的 JS 代码并未执行。我们猜测可能是缓存引起的,于是使用 meta 禁止了缓存,但仍然没有效果。于是进一步猜测可能是浏览器内部机制导致——ios为了提升浏览网页的效率,可能给已浏览过的网页添加一个类似快照的东西,当点击返回按钮后,直接调用快照展示给用户,省去了执行JS这一步骤(纯静态文件依然被缓存)。
于是想到一个hack方法:
//C页面
sessionStorage.setItem('isHistory', 'true');
// B页面
if(navigator.userAgent.match( /(?:iPad|iPod|iPhone).*OS\s([\d_]+)/ )) {
var timer = setInterval(function(){
if(sessionStorage.getItem('isHistory') == 'true') {
sessionStorage.setItem('isHistory', 'false');
timer = null;
location.reload();
}
},30);
}
===== end =====
分析需求
显然,此需求有两个功能:
- 页面中的返回上一页功能
- C中添加内容,返回B后刷新页面,同时保证B页面返回功能的正常使用
解决方案
针对第一个问题,我们很容易想到history.back()
或者history.go(-1)
难点在第二个问题,最开始我是这样解决的:loacation.href = document.referrer
,此时,B页面内容正确显示,但点击返回按钮却到了C。
分析原因,原来是loacation.href
相当于重新加载了一次B页面,那么当前B页面的上一页自然就是C了。
有没有办法使得B页面不重新加载,但更新内容呢?
使用Ajax!!!浏览器加载页面后,会缓存HTML,每次加载页面都会执行一遍JS
1、C 页面点击确定后使用history.go(-1)
,返回到B页面
2、在 B 页面通过$.ajax()
获取内容
var xhr = $.ajax({
type: 'GET',
url: '/api/xxx/xx',
timeout: 5000,
dataType: 'json',
beforeSend: function(XHR){
// todo
},
success: function(json){
//
},
error: function(){},
complete: function(xhr,status){}
})
3、重点,使用自执行函数渲染页面
<script>
function B(){};
B.prototype.getData(){
var xhr = $.ajax({...})
};
B.prototype.renderPage(){
this.getDate();
// render...
};
!function(window){
var b = new B();
b.renderPage();
}(window)
</script>
这下应该成了吧。NO! C点击确定后返回到B,B内容依然没有更新。。。
这是为什么呢?
百度搜索无果,情急之下只有求救大神
大神说,可能是GET
请求发出后,由于URL没有变化,浏览器可能会从缓存中读取数据而导致内容更新失败。
- 使用POST请求,强制从服务器获取数据
- 仍然使用GET,改变当前页面的
url
,方法是在url
末尾添加一段随机字符串
两种方法都能实现需求,这里再说说方法二:
var xhr = $.ajax({
type: 'GET',
url: '/api/xxx/xx',
timeout: 5000,
dataType: 'json',
data: {flag: new Date().getTime().toString(36)}, // 在GET方法内添加一个任意key,随机字符串改变
beforeSend: function(XHR){
// todo
},
success: function(json){
//
},
error: function(){},
complete: function(xhr,status){}
})
JS 返回上一页并刷新,但不用重新加载整个页面(ajax实现)的更多相关文章
- js返回上一页并刷新的多种方法
js返回上一页并刷新的几种方法.参考链接:http://www.jbxue.com/article/11230.html <a href="javascript:history.go( ...
- 高并发分布式系统中生成全局唯一(订单号)Id js返回上一页并刷新、返回上一页、自动刷新页面 父页面操作嵌套iframe子页面的HTML标签元素 .net判断System.Data.DataRow中是否包含某列 .Net使用system.Security.Cryptography.RNGCryptoServiceProvider类与System.Random类生成随机数
高并发分布式系统中生成全局唯一(订单号)Id 1.GUID数据因毫无规律可言造成索引效率低下,影响了系统的性能,那么通过组合的方式,保留GUID的10个字节,用另6个字节表示GUID生成的时间(D ...
- js返回上一页并刷新的多种实现方法
<a href="javascript:history.go(-1)">返回上一页</a> <a href="javascript:loca ...
- js返回上一页并刷新代码整理
一:JS 重载页面,本地刷新,返回上一页 复制代码 代码如下: <a href="javascript:history.go(-1)">返回上一页</a> ...
- js返回上一页并刷新、返回上一页、自动刷新页面
一.返回上一页并刷新 <a href="javascript:" onclick="self.location=document.referrer;"&g ...
- JS返回上一页并刷新
window.history.go(-1);//返回上一页不刷新 window.location.href = document.referrer;//返回上一页并刷新
- js返回上一页并刷新的几种方法
1.返回上一页 1)<a href="javascript:history.go(-1)"></a> 2)<a href="javascri ...
- js 返回上一页和刷新
1. Javascript 返回上一页history.go(-1), 返回两个页面: history.go(-2); 2. history.back(). 3. window.history.forw ...
- JS 返回上一页并刷新代码整理
一:JS 重载页面,本地刷新,返回上一页: <a href="javascript:history.go(-1)">返回上一页</a> <a href ...
- Js返回上一页,刷新页面,定时刷新,改变地址栏 等常用实用技巧
1. Javascript 返回上一页history.go(-1), 返回两个页面: history.go(-2); 2. history.back(). 3. window.history.forw ...
随机推荐
- mysql安装版卸载,解压版安装
卸载:https://blog.csdn.net/cxy_summer/article/details/70142322 解压版安装:https://blog.csdn.net/recky_wiers ...
- react-native 打包 出apk
先上步骤: 一. 生成签名文件(my-release-key.keystore文件) Android要求所有应用都有一个数字签名才会被允许安装在用户手机上 1. 在项目目录下运行如下命令: keyt ...
- UNITY_INITIALIZE_OUTPUT宏
UNITY_INITIALIZE_OUTPUT宏 UNITY_INITIALIZE_OUTPUT(type,name) –此宏用于将给定类型的名称变量初始化为零.在使用旧版标准所写的Shader时,经 ...
- _MainTex_TexelSize what's the meaning?
uniform float4 _MainTex_TexelSize where is the value of the float4 _MainTexelSize from? It's set by ...
- 综合:bool类型 命名空间 输入输出
----------siwuxie095 题目要求: 使用一个函数找出一个整型数组中的最大值或最小值 注意: 1.直接书写 cin cout endl, ...
- Golang之fmt格式“占位符”
golang的fmt包实现了格式化I/O函数: package main import "fmt" type Human struct { Name string } func m ...
- BZOJ 2002 Bounce 弹飞绵羊 (分块或动态树)
2002: [Hnoi2010]Bounce 弹飞绵羊 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 13768 Solved: 6989[Subm ...
- 检测Linux系统是否支持某系统调用
随内核版本的变化,会增加一些新的系统调用,但如果glibc没有跟上,则不能直接调用,这个时候可以自己包装一下.如果想知道内核是否支持某系统调用,先得知道它的系统调用ID号,下面代码即是用来检查是否支持 ...
- Android-DateTimeAndroidUtil-工具类
DateTimeAndroidUtil-工具类 是关于时间日前相关的公用方法: package liudeli.mynetwork01.utils; import android.util.Log; ...
- Android-隐式意图激活操作系统通话界面
阅读Android操作系统的 packages/apps/phone/AndroidManifest.xml,是如何暴露的 AndroidManifest.xml Android操作系统在这里明确 ...