【Vue3实战】:用导航守卫拦截未保存的编辑,提升用户体验

前言

在Vue3应用中,用户可能会在一个页面上进行数据编辑,如填写表单或修改表格中的数据。当用户在未保存更改的情况下尝试离开当前页面时,我们希望能够弹出提示框,告知用户有未保存的更改,并询问是否确定离开。

一、使用 onBeforeRouteLeave 导航守卫

1. 安装Vue Router

首先,确保你的项目中已经安装了Vue Router。如果还没有安装,可以使用以下命令进行安装:

bash 复制代码
npm install vue-router@next

2. 设置路由和组件

假设我们编辑数据页面。在这个组件中,我们需要定义onBeforeRouteLeave导航守卫。

TypeScript 复制代码
<script>
import {defineComponent} from 'vue';
import {onBeforeRouteLeave} from "vue-router";

export default defineComponent({
  setup() {

    // 导航守卫
    onBeforeRouteLeave((to, from, next) => {
      // 换成各自UI对话框组件
      const reply = window.confirm('确定离开当前页面?');
      if (reply) {
        next(); // 用户确认离开,继续导航
      } else {
        next(false); // 用户取消离开,阻止导航
      }
    });


    return {
      //...
    }
  }
})
</script>

二、效果验证

现在,当你修改表单中的数据并尝试离开页面时,会弹出一个确认对话框,提示你有未保存的更改。

总结

通过利用Vue Router的onBeforeRouteLeave导航守卫,我们可以有效地防止用户在未保存更改的情况下误点离开页面。这种方法不仅简单实用,而且能够显著提升用户体验。在实际开发中,你还可以根据具体需求对导航守卫进行更多的自定义和扩展。

希望本文能够帮助你解决Vue3应用中的编辑误点忘记保存的问题。如果你有任何疑问或建议,请随时在评论区留言。

相关推荐
滚雪球~33 分钟前
npm error code ETIMEDOUT
前端·npm·node.js
沙漏无语34 分钟前
npm : 无法加载文件 D:\Nodejs\node_global\npm.ps1,因为在此系统上禁止运行脚本
前端·npm·node.js
supermapsupport36 分钟前
iClient3D for Cesium在Vue中快速实现场景卷帘
前端·vue.js·3d·cesium·supermap
brrdg_sefg37 分钟前
WEB 漏洞 - 文件包含漏洞深度解析
前端·网络·安全
胡西风_foxww44 分钟前
【es6复习笔记】rest参数(7)
前端·笔记·es6·参数·rest
m0_748254881 小时前
vue+elementui实现下拉表格多选+搜索+分页+回显+全选2.0
前端·vue.js·elementui
星就前端叭2 小时前
【开源】一款基于Vue3 + WebRTC + Node + SRS + FFmpeg搭建的直播间项目
前端·后端·开源·webrtc
m0_748234522 小时前
前端Vue3字体优化三部曲(webFont、font-spider、spa-font-spider-webpack-plugin)
前端·webpack·node.js
Web阿成2 小时前
3.学习webpack配置 尝试打包ts文件
前端·学习·webpack·typescript
苹果醋32 小时前
Golang的文件加密工具
运维·vue.js·spring boot·nginx·课程设计