1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > 点击浏览器的返回按钮 就会刷新历史页面这个问题的解决方案

点击浏览器的返回按钮 就会刷新历史页面这个问题的解决方案

时间:2021-08-07 09:58:45

相关推荐

点击浏览器的返回按钮 就会刷新历史页面这个问题的解决方案

web前端|html教程

Firefox,webkit,浏览器

web前端-html教程

首先我们知道这个问题是如何发生的,假如我们有如下页面列表信息页面,点击进入详情页面,在详情页面修改了数据通过历史返回,再返回到列表信息页面,因为列表信息是历史返回的,还是默认显示原来修改前的数据,要刷新一下才是修改后的数据,那么我们有什么办法可以点击手机返回按钮就可以刷新之前历史页面中的数据呢?

java 超市pos源码,vscode中auto怎么用,ubuntu全盘复制,tomcat 建站集成包,爬虫保湿介质,php 淘宝页面抓取,咸宁广告seo推广开户,导入源码制作网站软件,怎么仿网站页面模板lzw

onpageshow事件和onload事件。 onpageshow 事件类似于 onload 事件,onload 事件在页面第一次加载时触发, onpageshow 事件在每次加载页面时触发,即 onload 事件在页面从浏览器缓存中读取时不触发。

qq空间音乐提取e源码,vscode怎么撤回,ubuntu的用户名字,tomcat源码实现,sqlite%3e,jq滑动门插件,阿里的前端框架remix,网络爬虫主要步骤,php数组去除重复的,符合seo,图片墙类网站源码下载,打开网页延时弹窗代码,特效网页模板下载,小程序asp源码下载lzw

为了查看页面是直接从服务器上载入还是从缓存中读取,你可以使用 PageTransitionEvent 对象的 persisted 属性来判断。 如果页面从浏览器的缓存中读取该属性返回 ture,否则返回 false

天龙八部3源码答题器破解,vscode字放大快捷键,Ubuntu装htop,tomcat正在被使用,布什是爬虫,php apd安装,长乐网页seo费用是多少lzw

解决方案

通过onload方式

代码如下:

页面中写一个隐藏的input

js操作如下

onload=function(){ var refreshedId=document.getElementById("refreshed"); if(refreshedId.value=="no"){ refreshedId.value="yes"; } else{ refreshedId.value="no"; location.reload(); } }

通过onpageshow 方式

这种方式在电脑上是没有问题的,但是苹果safari中返回不执行onload事件,要用如下方式:

window.onpageshow = function(event) { if (event.persisted) { window.location.reload()}};

通过实际操作发现,event.persisted在电脑中一直是返回false,但是在手机safari中是没有问题的。

综合解决方案

因此,可以如下写代码:

if ((/iphone|ipod|ipad.*os 5/gi).test(navigator.appVersion)) { window.onpageshow = function(event) { if (event.persisted) {window.location.reload() } }; }else{ onload=function(){ var refreshedId=document.getElementById("refreshed"); if(refreshedId.value=="no"){refreshedId.value="yes";} else{ refreshedId.value="no"; location.reload(); } } }

通过上面代码发现在safari中第一次打开页面的时候,有时候会出现闪屏效果。

添加如下代码:

$(window).bind("unload", function() { });

就没有再出现闪屏效果了。

通过iframe方式阻止缓存

页面中添加如下代码

this prevents back forward cache

这种方式有待验证。

通过时间戳强制刷新方式

下面代码是针对iPad中safari返回按钮问题

var showLoadingBoxSetIntervalVar;var showLoadingBoxCount = 0;var showLoadingBoxLoadedTimestamp = 0function showLoadingBox(text) { var showLoadingBoxSetIntervalVar=self.setInterval(function(){showLoadingBoxIpadRelaod()},1000); showLoadingBoxCount = 0 showLoadingBoxLoadedTimestamp = new Date().getTime(); //Here load the spinner}function showLoadingBoxIpadRelaod(){ //计算时间超过500毫秒 var diffTime = ( (new Date().getTime()) - showLoadingBoxLoadedTimestamp - 500)/1000; showLoadingBoxCount = showLoadingBoxCount + 1; var isiPad = navigator.userAgent.match(/iPad/i) != null; if(diffTime > showLoadingBoxCount && isiPad){ location.reload(); }}

相信看了这些案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

相关阅读:

CSS的编码怎么转换

css3点击显示涟漪特效

怎样用canvas做出粒子喷泉动画的效果

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。