Vue踩坑之旅(二)—— 监听页面刷新和关闭__Vue.js
发布于 4 年前 作者 banyungong 2989 次浏览 来自 分享
粉丝福利 : 关注VUE中文社区公众号,回复视频领取粉丝福利

我在做项目的时候,有一个需求,在离开(跳转或者关闭)购物车页面或者刷新购物车页面的时候向服务器提交一次购物车商品数量的变化。

将提交的异步操作放到 beforeDestroy 钩子函数中。

beforeDestroy() {
  console.log('销毁组件')
  this.finalCart()
},

但是发现  beforeDestroy 只能监听到页面间的跳转,无法监听到页面刷新和关闭标签页。

所以还是要借助 onbeforeunload 事件。

顺便复习了一下 JavaScript 中的一些加载,卸载事件:

  • 页面加载时只执行 onload 事件。
  • 页面关闭时,先 onbeforeunload 事件,再 onunload 事件。
  • 页面刷新时先执行 onbeforeunload事件,然后 onunload 事件,最后 onload 事件。

Vue中监听页面刷新和关闭

1. 在methods中定义事件方法:

methods: {
  beforeunloadFn(e) {
    console.log('刷新或关闭')
    // ...
  }
}

2. 在created 或者 mounted 生命周期钩子中绑定事件

created() {
  window.addEventListener('beforeunload', e => this.beforeunloadFn(e))
}

3. 在 destroyed 钩子中卸载事件

destroyed() {
  window.removeEventListener('beforeunload', e => this.beforeunloadFn(e))
}

测试了页面刷新和关闭都能监听到。

回到我自己的项目,可以使用 onbeforeunload 事件和 beforeDestroy 钩子函数结合:

created() {
  this.initCart()
  window.addEventListener('beforeunload', this.updateHandler)
},
beforeDestroy() {
  this.finalCart() // 提交购物车的异步操作},
destroyed() {
  window.removeEventListener('beforeunload', this.updateHandler)},
methods: {
  updateHandler() {
    this.finalCart()
  },
  finalCart() {
    // ...
  }
}<p style="line-height: 20px; color: #ccc">
    版权声明:著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
    作者: lakey0126
    原文链接:<a href='https://juejin.im/post/6844903871668551687'>https://juejin.im/post/6844903871668551687</a>
  </p>
回到顶部