html5的pushstate以及监听浏览器返回事件的实现


Posted in HTML / CSS onAugust 11, 2020

pushstate与监听浏览器返回解决的问题

1.实际开发我们在A页面调用组件,在组件里面填好内容之后,发现想退出不想填了,因为组件与A页面此时在同一页面,点击返回时候 给人感觉是返回上上个页面,但之前A页面填写的东西 都没有了,这很影响体验。

因此可以使用pushstate方法,不刷新浏览器改变url 当你再返回时候就会返回到这个A页面而不是上上个页面。但此时还需要监听返回的按钮,进而控制组件的显示与隐藏。这点也至关重要。不然组件不隐藏,也就相当于没效果。

pushState

使用方法(一般情况)

function pushHistory() { 
var state = { title: "title", url: "#" }; 
window.history.pushState(state, "title", "#"); }

参数说明:

pushState() 带有三个参数:state是js对象,title是个标题(现在被忽略了),以及一个可选的URL地址。

关于pushstate的说明

浏览器不会向服务端请求数据,直接改变url地址,可以类似的理解为变相版的hash;但不像hash一样,浏览器会记录pushState的历史记录,可以使用浏览器的前进、后退功能作用。

监听浏览器返回按钮

window.addEventListener("popstate", function(e) { console.log(e); alert("我监听到了浏览器的返回按钮事件啦");//根据自己的需求实现自己的功能 }, false);

转自:https://segmentfault.com/a/1190000022696823

到此这篇关于html5的pushstate以及监听浏览器返回事件的实现的文章就介绍到这了,更多相关html5的pushstate实现内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

HTML / CSS 相关文章推荐
button在IE6/7下的黑边去除方案
Dec 24 HTML / CSS
CSS3控制HTML元素动画效果
Feb 08 HTML / CSS
利用CSS3把图片变成灰色模式的实例代码
Sep 06 HTML / CSS
CSS3动画:5种预载动画效果实例
Apr 05 HTML / CSS
详解利用css3的var()实现运行时改变scss的变量值
Mar 02 HTML / CSS
Html5 Canvas 实现一个“刮刮乐”游戏
Sep 05 HTML / CSS
Javascript 高级手势使用介绍
Apr 21 HTML / CSS
html5组织内容_动力节点Java学院整理
Jul 10 HTML / CSS
h5网页水印SDK的实现代码示例
Feb 19 HTML / CSS
关于html字符串正则判断和匹配的具体使用
Dec 12 HTML / CSS
纯 CSS 自定义多行省略的问题(从原理到实现)
Nov 11 HTML / CSS
浅谈css实现背景颜色半透明的两种方法
Dec 06 HTML / CSS
canvas画图被放大且模糊的解决方法
Aug 11 #HTML / CSS
在html页面中取得session中的值的方法
Aug 11 #HTML / CSS
canvas实现滑动验证的实现示例
Aug 11 #HTML / CSS
解决html5中的video标签ios系统中无法播放使用的问题
Aug 10 #HTML / CSS
Html5 webview元素定位工具的实现
Aug 07 #HTML / CSS
HTML5 video循环播放多个视频的方法步骤
Aug 06 #HTML / CSS
html5 video全屏播放/自动播放的实现示例
Aug 06 #HTML / CSS
You might like
浅析php中常量,变量的作用域和生存周期
2013/08/10 PHP
php定界符
2014/06/19 PHP
Apache服务器下防止图片盗链的办法
2015/07/06 PHP
CodeIgniter配置之autoload.php自动加载用法分析
2016/01/20 PHP
JQUERY CHECKBOX全选,取消全选,反选方法三
2008/08/30 Javascript
2010年最佳jQuery插件整理
2010/12/06 Javascript
jquery使用ajax实现微信自动回复插件
2014/04/28 Javascript
jQuery中:has选择器用法实例
2014/12/30 Javascript
js对象基础实例分析
2015/01/13 Javascript
7个让JavaScript变得更好的注意事项
2015/01/28 Javascript
使用重写url机制实现验证码换一张功能
2017/08/01 Javascript
js数组常用最重要的方法
2018/02/04 Javascript
Vue.js进阶知识点总结
2018/04/01 Javascript
nodejs中方法和模块用法示例
2018/12/24 NodeJs
从0到1构建vueSSR项目之路由的构建
2019/03/07 Javascript
利用node 判断打开的是文件 还是 文件夹的实例
2019/06/10 Javascript
vue中created和mounted的区别浅析
2019/08/13 Javascript
node使用request请求的方法
2019/12/20 Javascript
详解Webpack4多页应用打包方案
2020/07/16 Javascript
[01:21]2018DOTA2亚洲邀请赛4.5采访 打DOTA2也能有女朋友?
2018/04/06 DOTA
基于Python的身份证号码自动生成程序
2014/08/15 Python
Python3学习笔记之列表方法示例详解
2017/10/06 Python
flask + pymysql操作Mysql数据库的实例
2017/11/13 Python
Python 25行代码实现的RSA算法详解
2018/04/10 Python
python执行系统命令后获取返回值的几种方式集合
2018/05/12 Python
python3 selenium 切换窗口的几种方法小结
2018/05/21 Python
python 计算数据偏差和峰度的方法
2019/06/29 Python
Python logging模块异步线程写日志实现过程解析
2020/06/30 Python
印度购物网站:TATA CLiQ
2017/11/23 全球购物
The North Face北面荷兰官网:美国著名户外品牌
2019/10/16 全球购物
在线实验室测试:HealthLabs.com
2020/05/03 全球购物
跳蚤市场口号
2014/06/13 职场文书
涨价通知
2015/04/23 职场文书
英语专业毕业论文答辩开场白
2015/05/27 职场文书
建国大业观后感800字
2015/06/01 职场文书
springboot + mongodb 通过经纬度坐标匹配平面区域的方法
2021/11/01 MongoDB