设为首页收藏本站
天天打卡

 找回密码
 立即注册
搜索
查看: 110|回复: 9

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

[复制链接]

2

主题

39

回帖

123

积分

注册会员

积分
123
发表于 2024-4-20 10:29:53 | 显示全部楼层 |阅读模式
pushstate与监听浏览器返回解决的问题
1.实际开发我们在A页面调用组件,在组件里面填好内容之后,发现想退出不想填了,因为组件与A页面此时在同一页面,点击返回时候 给人感觉是返回上上个页面,但之前A页面填写的东西 都没有了,这很影响体验。
因此可以使用pushstate方法,不刷新浏览器改变url 当你再返回时候就会返回到这个A页面而不是上上个页面。但此时还需要监听返回的按钮,进而控制组件的显示与隐藏。这点也至关重要。不然组件不隐藏,也就相当于没效果。
pushState
使用方法(一般情况)
  1. function pushHistory() {
  2. var state = { title: "title", url: "#" };
  3. window.history.pushState(state, "title", "#"); }
复制代码
参数说明:
pushState() 带有三个参数:state是js对象,title是个标题(现在被忽略了),以及一个可选的URL地址。
关于pushstate的说明
浏览器不会向服务端请求数据,直接改变url地址,可以类似的理解为变相版的hash;但不像hash一样,浏览器会记录pushState的历史记录,可以使用浏览器的前进、后退功能作用。
监听浏览器返回按钮
  1. window.addEventListener("popstate", function(e) { console.log(e); alert("我监听到了浏览器的返回按钮事件啦");//根据自己的需求实现自己的功能 }, false);
复制代码
转自:https://segmentfault.com/a/1190000022696823
到此这篇关于html5的pushstate以及监听浏览器返回事件的实现的文章就介绍到这了,更多相关html5的pushstate实现内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

0

主题

61

回帖

122

积分

注册会员

积分
122
发表于 2024-4-27 13:30:01 | 显示全部楼层
这个话题很有趣,我想多了解一些
  • 打卡等级:初来乍到
  • 打卡总天数:3
  • 打卡月天数:0
  • 打卡总奖励:59
  • 最近打卡:2024-05-05 22:01:24

5

主题

62

回帖

295

积分

中级会员

积分
295
发表于 2024-6-26 10:11:11 | 显示全部楼层
确实牛逼

2

主题

73

回帖

191

积分

注册会员

积分
191
发表于 2024-7-4 10:41:30 | 显示全部楼层
太棒了!感谢分享这个信息!

2

主题

52

回帖

150

积分

注册会员

积分
150
发表于 2024-7-23 13:01:24 | 显示全部楼层
让我们一起努力

2

主题

49

回帖

143

积分

注册会员

积分
143
发表于 2024-8-20 19:39:53 | 显示全部楼层
好用好用

0

主题

53

回帖

107

积分

等待验证会员

积分
107
发表于 2024-8-28 14:26:35 | 显示全部楼层
顶一个,观点非常中肯!

1

主题

30

回帖

84

积分

注册会员

积分
84
发表于 2024-9-6 11:42:41 | 显示全部楼层
保持尊重和礼貌对待其他成员是必要的。

0

主题

52

回帖

103

积分

注册会员

积分
103
发表于 2024-10-10 07:03:37 | 显示全部楼层
谢谢你分享这个信息

2

主题

41

回帖

127

积分

注册会员

积分
127
发表于 前天 22:26 | 显示全部楼层
666666666666
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|爱云论坛 - d.taiji888.cn - 技术学习 免费资源分享 ( 蜀ICP备2022010826号 )|天天打卡

GMT+8, 2024-11-24 07:41 , Processed in 0.098864 second(s), 26 queries .

Powered by i云网络 Licensed

© 2023-2028 正版授权

快速回复 返回顶部 返回列表