JavaScript中,返回上一个页面时,如何保证上一个页面的不刷新?
History 对象包含用户(在浏览器窗口中)访问过的 URL。
浏览器在默认情况下会缓存input输入框的值,autocomplete="on" 默认有这个属性, 只有使用Ctrl+F5强制刷新,或者a标签重新跳转才可以清除缓存记录。
<input type="text" autocomplete="on">
这时候history.go(-1),history.back()表单会从缓存中取值,但js还是会执行的。所以这里的刷新是否大家判断不一致,这是判断标准不一样。
要实现js也不执行效果,可以利用sessionStorage,再下一个页面要返回的时候在sessionStorage中存储一个参数。
let box = document.querySelector('.box'); box.onclick=function(){ sessionStorage.setItem('isTrue',true); history.back() }
在表单页获取sessionStorage存储的参数,用来判断js是否执行。最后再从sessionStorage中移除这个参数就可以了。
if (!sessionStorage.getItem('isTrue')) { console.log('js执行了'); }else{ sessionStorage.removeItem("isTrue"); //从sessionStorage中移除这个参数 }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)