有这样一个需求,当在用户在浏览器点击返回按钮的时候,需要弹出当前组件的退出确认框。并且如果当前页面有个已经打开了的弹窗时,弹窗还没关闭就点击浏览器的返回按钮,要求点击返回时,弹窗要关闭。
解决:
import { onMounted, onUnmounted } from 'vue';
// 浏览器返回时的 TODO
const handlePopState = () => {
console.log('222222');
};
onMounted(() => {
// 监听浏览器的返回按钮事件 popstate
window.addEventListener('popstate', handlePopState);
});
onUnmounted(() => {
// 移除浏览器的返回按钮事件 popstate
window.removeEventListener('popstate', handlePopState);
});
当组件被挂载时,添加了一个popstate
事件监听器。当用户点击浏览器返回按钮时,会触发popstate
事件。在组件被卸载时,确保移除事件监听器,避免内存泄漏。