Vue监听并自定义浏览器返回事件方案

概要

最近项目上使用Uniapp开发一款APP,使用webview打开vue开发的H5页面,从app端进入H5的列表页,再由列表页进入详情页再进入提交表单页,表单提交成功后会自动跳转回列表页,这时再点击app自带的返回按钮,会返回到填写表单页,但是项目上希望返回到app端的首页

原因

每次进入一次页面,都会往页面栈中压入一条记录,返回也是返回上一个页面,使用vue router的replace方法也只是将当前页面从栈中替换掉,无法解决问题

方案

通过查阅了一些资料,总结出来的思路是使用pushState像浏览器历史记录中插入一个不刷新的当前页,这样在返回的时候就可以通过监听popstate去处理一些自定义的跳转逻辑,具体代码如下

	// 在需要处理自定义返回的页面中添加监听事件 
	onBeforeMount(() => {
      if (window.history && window.history.pushState) {
        // 向历史记录中插入了当前页
        history.pushState(null, null, location.href)
        window.addEventListener('popstate', goBack)
      }
 	})
	// 在离开页面前销毁监听事件 
	onBeforeUnmount(() => {
      window.removeEventListener('popstate', goBack)
    })
	// 自定返回事件
	const goBack = () => {
	  // 此处可以根据自己业务去定制化返回逻辑,可以调用原生提供的方法关闭webview从而达到返回APP页面的目的
      console.log('点击了浏览器的返回按钮')
    }

技术概念

1. history.pushState()

参考资料:https://blog.youkuaiyun.com/weixin_39667945/article/details/88563003

2.addEventListener()

参考资料:https://blog.youkuaiyun.com/Alexbyy/article/details/91388862

### Vue 监听浏览器返回事件的解决方案Vue监听浏览器返回事件,可以通过 `popstate` 事件实现。以下是完整的实现方法和代码示例: #### 添加事件监听器 在组件挂载时,通过 `mounted` 钩子添加 `popstate` 事件监听器[^1]。 ```javascript export default { mounted() { if (window.history && window.history.pushState) { history.pushState(null, null, document.URL); window.addEventListener('popstate', this.handlePopstate, false); } }, methods: { handlePopstate(event) { // 自定义返回逻辑 this.$router.replace({ path: '/' }); // 返回到指定页面 } } }; ``` #### 销毁事件监听器 在组件销毁时,通过 `beforeDestroy` 或 `unmounted` 钩子移除 `popstate` 事件监听器,以避免内存泄漏[^2]。 ```javascript export default { beforeDestroy() { window.removeEventListener('popstate', this.handlePopstate, false); } }; ``` #### 注意事项 1. **确保事件绑定一致性**:`addEventListener` 和 `removeEventListener` 必须绑定同一个函数实例,否则无法正确移除事件监听器[^3]。 2. **动态修改地址栏**:使用 `history.pushState` 方法可以动态修改浏览器地址栏而不刷新页面[^4]。 3. **Vue Router 集成**:通过 `this.$router.replace` 方法实现页面跳转,确保与 Vue Router 的路由状态保持一致。 #### 完整代码示例 以下是一个完整的 Vue 组件示例,展示如何监听处理浏览器返回事件: ```javascript export default { mounted() { if (window.history && window.history.pushState) { history.pushState(null, null, document.URL); // 向历史记录栈中插入当前页 window.addEventListener('popstate', this.handlePopstate, false); // 添加事件监听器 } }, beforeDestroy() { window.removeEventListener('popstate', this.handlePopstate, false); // 移除事件监听器 }, methods: { handlePopstate() { console.log('触发了浏览器返回事件'); this.$router.replace({ path: '/' }); // 自定义返回逻辑,例如跳转到首页 } } }; ``` #### 技术概念 1. **`history.pushState()`**:用于向浏览器历史记录栈中插入一条记录,而不会触发页面刷新[^4]。 2. **`addEventListener()`**:用于为特定事件(如 `popstate`)注册监听器。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值