vue3判断elementui中el-form是否更新变化,变化就提示是否保存,没变就直接离开

需求是:如果用户在表单中输入了内容,但是没有点击保存,而突然想离开这个页面了,就要提示询问是否保存,这个时候就要判断表单内容是否发生变化,并做相应的逻辑控制

1.方法说明:

watch和watchEffect是Vue 3.0中新增的两个响应式API,用于监听数据的变化。watch适用于需要获取新值和旧值,或者需要懒执行的场景,而watchEffect适用于需要监听多个数据源,并且需要立即执行的场景。它们之间的区别如下:

watch是监听单个数据源,可以设置immediate和deep选项,可以获取新值和旧值;watchEffect则是监听一组数据源,不能设置immediate和deep选项,不能获取新值和旧值。

watch是懒执行的,只有在数据变化时才会执行回调函数,而watchEffect则是立即执行的,不管数据是否变化。

javascript 复制代码
<template>
  <el-form :model="formData">
    <el-form-item label="用户名">
      <el-input v-model="formData.username"></el-input>
    </el-form-item>
    <!-- 其他表单项 -->
  </el-form>
</template>
 
<script setup>
import { reactive, watch, watchEffect } from 'vue';
import { ElMessageBox } from 'element-plus';
 
const formData = reactive({
  username: '',
  // 其他表单数据
});
 
// 使用watchEffect来监听整个formData对象的变化
watchEffect(() => {
  const isDirty = Object.keys(formData).some(key => formData[key] !== initialFormData[key]);
  if (isDirty) {
    // 表单数据有变化
    ElMessageBox.confirm('您有未保存的更改,是否保存?', '提示', {
      confirmButtonText: '保存',
      cancelButtonText: '放弃',
      type: 'warning'
    }).then(() => {
      // 保存逻辑
    }).catch(() => {
      // 取消逻辑
    });
  }
}, {
  flush: 'post' // 确保在DOM更新后执行
});
 
// 初始表单数据,用于比较
const initialFormData = { ...formData };
</script>

watchEffect会在响应式依赖变化时执行,并通过比较formDatainitialFormData来判断表单数据是否有变化。如果有变化,会弹出消息框询问用户是否保存更改。如果没有变化,用户离开时不会有任何提示

相关推荐
coderYYY18 分钟前
git push报错Authentication failed for ‘xxx’也不会弹要求输入用户名密码的最终解决方法
前端·git·gitee·github
l1t1 小时前
QWen 3.5plus总结的总结基准测试结果的正确方法
前端·数据库
kyriewen111 小时前
为什么我的代码在测试环境跑得好好的,一到用户电脑就崩?原来凶手躲在地址栏旁边
开发语言·前端·javascript·chrome·ecmascript·html5
小北方城市网1 小时前
JavaScript 实战 —— 实现一个简易的 TodoList(适合前端入门 / 进阶)
开发语言·前端·javascript
是上好佳佳佳呀1 小时前
【前端(二)】CSS 知识梳理:从编写位置到选择器优先级
前端·css
倾颜2 小时前
我是怎么把单 Tool Calling 升级成多 Tool Runtime 的
前端·后端·langchain
清汤饺子2 小时前
Superpowers:给 AI 编程 Agent 装上"工程化超能力"
前端·javascript·后端
踩着两条虫2 小时前
AI驱动的Vue3应用开发平台 深入探究(十三):物料系统之区块与页面模板
前端·vue.js·人工智能·架构·系统架构
weixin199701080162 小时前
《得物商品详情页前端性能优化实战》
前端·性能优化
帮我吧智能服务平台3 小时前
装备制造企业售后服务数字化:从成本中心到利润中心背景
java·前端·制造