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 相关文章推荐
CSS3 渐变(Gradients)之CSS3 线性渐变
Jul 08 HTML / CSS
CSS3 中的@keyframes介绍
Sep 02 HTML / CSS
纯css3实现思维导图样式示例
Nov 01 HTML / CSS
用CSS3和table标签实现一个圆形轨迹的动画的示例代码
Jan 17 HTML / CSS
css3中仿放大镜效果的几种方式原理解析
Dec 03 HTML / CSS
HTML5 Canvas像素处理使用接口介绍
Dec 02 HTML / CSS
HTML5 audio标签使用js进行播放控制实例
Apr 24 HTML / CSS
html5如何在Canvas中实现自定义路径动画示例
Sep 18 HTML / CSS
html5 http的轮询和Websocket原理
Oct 19 HTML / CSS
HTML5页面无缝闪开的问题及解决方案
Jun 11 HTML / CSS
html css3不拉伸图片显示效果
Jun 07 HTML / CSS
POST提交数据常见的四种方式
Jan 18 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读取mysql中文数据出现乱码的解决方法
2013/08/16 PHP
合格的PHP程序员必备技能
2015/11/13 PHP
AJAX PHP无刷新form表单提交的简单实现(推荐)
2016/09/09 PHP
PHP中类的自动加载的方法
2017/03/17 PHP
php连接MSsql server的五种方法总结
2018/03/04 PHP
prototype Element学习笔记(篇二)
2008/10/26 Javascript
JavaScript入门教程(5) js Screen屏幕对象
2009/01/31 Javascript
把html页面的部分内容保存成新的html文件的jquery代码
2009/11/12 Javascript
jquery利用ajax调用后台方法实例
2013/08/23 Javascript
AngularJs expression详解及简单示例
2016/09/01 Javascript
javascript编写简易计算器
2017/05/06 Javascript
js学习总结_选项卡封装(实例讲解)
2017/07/13 Javascript
Vue.js中的图片引用路径的方式
2017/07/28 Javascript
Vue Cli与BootStrap结合实现表格分页功能
2017/08/18 Javascript
阿里大于短信验证码node koa2的实现代码(最新)
2017/09/07 Javascript
基于vue展开收起动画的示例代码
2018/07/05 Javascript
用Golang运行JavaScript的实现示例
2019/11/25 Javascript
JS数组方法slice()用法实例分析
2020/01/18 Javascript
js实现无限层级树形数据结构(创新算法)
2020/02/27 Javascript
JS猜数字游戏实例讲解
2020/06/30 Javascript
[51:00]Secret vs VGJ.S 2018国际邀请赛淘汰赛BO3 第一场 8.24
2018/08/25 DOTA
pymongo实现多结果进行多列排序的方法
2015/05/16 Python
Python实现的破解字符串找茬游戏算法示例
2017/09/25 Python
Python下载网络小说实例代码
2018/02/03 Python
scrapy-redis的安装部署步骤讲解
2019/02/27 Python
Python代理IP爬虫的新手使用教程
2019/09/05 Python
python 利用百度API识别图片文字(多线程版)
2020/12/14 Python
香港百佳网上超级市场:PARKNSHOP.com
2020/06/10 全球购物
八一建军节营销活动方案
2014/08/31 职场文书
小学假期安全广播稿
2014/09/28 职场文书
2014年化工厂工作总结
2014/11/25 职场文书
企业介绍信范文
2015/01/30 职场文书
授权协议书范本(3篇)
2019/10/15 职场文书
导游词之南京夫子庙
2019/12/09 职场文书
Jupyter notebook 不自动弹出网页的解决方案
2021/05/21 Python
MySQL基础快速入门知识总结(附思维导图)
2021/09/25 MySQL