在vue项目中利用popstate处理页面返回的操作介绍
需求背景项目中需要做一个返回确认,避免用户误触返回键而退出当前页面。
原理利用history和浏览器刷新popstate状态
实现
1、在mounted() 阶段判断并添加popstate事件监听,History.pushState()(参数一个状态对象,一个标题(现在被忽略了),以及一个可选的URL地址), 注意IOS版的微信,是会立即触发popstate事件,所以需要pageshow做下处理,(当一条会话历史记录被执行的时候将会触发页面显示(pageshow)事件。(这包括了后退/前进按钮操作,也会在onload 事件触发后初始化页面时触发))
2、在methods里定义监听操作函数
3、页面销毁时,取消监听。(注意一定要取消监听,否则其他vue路由页面也会被监听)
补充知识vue项目监测浏览器返回按钮
在WebApp或浏览器中,会有点击返回、后退、上一页等按钮实现自己的关闭页面、调整到指定页面、确认离开页面或执行一些其它操作的需求。可以使用 popstate 事件进行监听返回、后退、上一页操作。
简单介绍history中的操作
window.history.back(),后退
window.history.forward(),前进
window.history.go(num),前进或后退指定数量历史记录
window.history.pushState(state,title,url),在页面中穿件一个history实体。直接添加到历史记录中。参数 state:储存一个对象,可以添加相关信息,可以使用history.state读取其中的内容。title: 历史记录的标题,url:创建的历史记录rul,进行历史记录操作时会跳转到该链接。
window.history.replaceState(),修改当前的history实体。
popstate事件,history实体改变时触发事件
window.history.state,会获得history实体中的state对象。
使用方法
取消默认的返回操作
添加一条history实体作为替代原来的history实体
mounted () { if(window.history&&window.history.pushState){ history.pushState(null,null,document.URL) window.addEventListener('popstate', this.goBack, false); } }, destroyed(){ window.removeEventListener('popstate',this.goBack,false); }, methods:{ goBack(){ this.$router.replace({path:'/'}); //replace替换原路由,作用是避免回退死循环 } }
以上这篇在vue项目中利用popstate处理页面返回的操作介绍就是长沙网络推广分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持狼蚁SEO。
编程语言
- 甘肃哪有关键词排名优化购买方式有哪些
- 甘肃SEO如何做网站优化
- 河南seo关键词优化怎么做电话营销
- 北京SEO优化如何做QQ群营销
- 来宾百度关键词排名:提升您网站曝光率的关键
- 卢龙关键词优化:提升您网站排名的策略与技巧
- 山东网站优化的注意事项有哪些
- 四川整站优化怎样提升在搜索引擎中的排名
- 疏附整站优化:提升网站性能与用户体验的全新
- 海南seo主要做什么工作售后服务要做到哪些
- 荣昌百度网站优化:提升您网站的搜索引擎排名
- 河北seo网站排名关键词优化如何做SEO
- 江西优化关键词排名推广售后保障一般有哪些
- 古浪SEO优化:提升你的网站可见性
- 西藏网站排名优化怎么把网站排名在百度首页
- 如何提升阳东百度快照排名:详尽指南