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 相关文章推荐
CSS中一些@规则的用法小结
Mar 09 HTML / CSS
使用css3绘制出各种几何图形
Aug 17 HTML / CSS
CSS3+font字体文件实现圆形半透明菜单具体步骤(图解)
Jun 03 HTML / CSS
css3通过scale()、rotate()实现放大、旋转
Mar 19 HTML / CSS
检测浏览器是否支持html5视频的代码
Mar 28 HTML / CSS
HTML5 input元素类型:email及url介绍
Aug 13 HTML / CSS
html5桌面通知(Web Notifications)实例解析
Jul 07 HTML / CSS
使用html5 canvas 画时钟代码实例分享
Nov 11 HTML / CSS
Html5页面内使用JSON动画的实现
Jan 29 HTML / CSS
html5手机键盘弹出收起的处理
Jan 20 HTML / CSS
使用placeholder属性设置input文本框的提示信息
Feb 19 HTML / CSS
纯CSS实现hover图片pop-out弹出效果的实例代码
Apr 16 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 flock 文件锁详细介绍
2012/12/29 PHP
php定义参数数量可变的函数用法实例
2015/03/16 PHP
CI框架数据库查询缓存优化的方法
2016/11/21 PHP
Laravel构建即时应用的一种实现方法详解
2017/08/31 PHP
SyntaxHighlighter代码加色使用方法
2008/09/07 Javascript
javascript 贪吃蛇实现代码
2008/11/22 Javascript
javascript IFrame 强制刷新代码
2009/07/23 Javascript
探讨js中的双感叹号判断
2013/11/11 Javascript
php的文件上传入门教程(实例讲解)
2014/04/10 Javascript
Javascript WebSocket使用实例介绍(简明入门教程)
2014/04/16 Javascript
轻松创建nodejs服务器(7):阻塞操作的实现
2014/12/18 NodeJs
jquery实现点击页面回到顶部
2016/11/23 Javascript
js实现年月日表单三级联动
2020/04/17 Javascript
Angular.JS利用ng-disabled属性和ng-model实现禁用button效果
2017/04/05 Javascript
vue高德地图之玩转周边
2017/06/16 Javascript
js获取元素的偏移量offset简单方法(必看)
2017/07/05 Javascript
Vue 换肤的示例实践
2018/01/23 Javascript
理解Koa2中的async&await的用法
2018/02/05 Javascript
angular 实现同步验证器跨字段验证的方法
2019/04/11 Javascript
elementUI Tree 树形控件的官方使用文档
2019/04/25 Javascript
webpack常用配置总览(小结)
2019/11/18 Javascript
在js文件中引入(调用)另一个js文件的三种方法
2020/09/11 Javascript
[02:41]《西雅图我们来了》2015国际邀请赛出征全记录
2015/07/23 DOTA
Python安装Flask环境及简单应用示例
2019/05/03 Python
Python面向对象进阶学习
2019/05/21 Python
python的pytest框架之命令行参数详解(上)
2019/06/27 Python
Python中的几种矩阵乘法(小结)
2019/07/10 Python
美国顶级品牌男士大码服装店:DXL
2017/08/30 全球购物
Move Free官方海外旗舰店:美国骨关节健康专业品牌
2017/12/06 全球购物
英国游戏机和游戏购物网站:365games.co.uk
2018/06/18 全球购物
银行实习生的自我评价
2013/12/09 职场文书
2014物价局民主生活会对照检查材料思想汇报
2014/09/24 职场文书
护士求职自荐信
2015/03/25 职场文书
正规欠条模板
2015/07/03 职场文书
2016小学优秀教师先进事迹材料
2016/02/26 职场文书
行政后勤人员工作计划应该怎么写?
2019/08/16 职场文书