vue 控制浏览器回退, 防止返回,屏蔽返回

该文讨论了一个JavaScript函数,用于在打开组件时管理浏览器的历史记录。通过使用`pushState`和监听`popstate`事件,它确保在用户点击返回时能关闭组件并清理历史。同时,文章包含了离开页面时的清理逻辑,移除事件监听器,以及使用路由`go(-1)`进行页面回退。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

// 打开组件
const openPdf = () => {
  if (window.history && window.history.pushState) {
    // 向历史记录中插入了当前页
    history.pushState(null, null, location.href);
    window.addEventListener(
      'popstate',
      function () {
        if (show.value) { // 组件开启的时候点了返回才拦截
          show.value = false;
          window.removeEventListener('popstate', function () {}, false);
        }
      },
      false
    );
  }
  show.value = true;
  };
const sign = () => {
  // show.value = false; // 关闭组件换成回退上一页,不然会导致路由历史多一条,返回要点两次才出去
  router.go(-1);
};
// 离开销毁
onBeforeUnmount(() => {
  window.removeEventListener('popstate', null, false);
});
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值