From ad77e25e868008e33a701084fd0e8c00a06cc6a0 Mon Sep 17 00:00:00 2001
From: yubo <autumnal_wind@yeah.net>
Date: 星期五, 10 四月 2026 22:18:14 +0800
Subject: [PATCH] feat(emp): 优化新增与编辑模式下的表单验证及提交处理
---
src/views/user/inemployees.vue | 68 ++++++++++++++++++++-------------
1 files changed, 41 insertions(+), 27 deletions(-)
diff --git a/src/views/user/inemployees.vue b/src/views/user/inemployees.vue
index 734e3b7..de9d9ad 100644
--- a/src/views/user/inemployees.vue
+++ b/src/views/user/inemployees.vue
@@ -364,7 +364,7 @@
<el-form
ref="empBaseInfoForm"
:model="empBaseInfoForm"
- :rules="rules"
+ :rules="isAdd ? addRules : rules"
label-position="right"
label-width="120px"
>
@@ -1207,11 +1207,7 @@
depts: [],
fileList: [],
rules: {
- archivesNumb: [{ required: true, message: '请输入档案号', trigger: 'blur' }, {
- max: 20,
- message: this.$t('rules.noMoreThan20'),
- trigger: 'blur'
- }],
+ archivesNumb: [{ max: 20, message: this.$t('rules.noMoreThan20'), trigger: 'blur' }],
empName: [{ required: true, message: '请输入姓名', trigger: 'blur' },
{ min: 2, max: 50, message: this.$t('rules.noMoreThan50'), trigger: 'blur' }],
empNumb: [{ required: true, message: '请输入员工编号', trigger: 'blur' },
@@ -1247,6 +1243,14 @@
family: [{ max: 128, message: '长度不超过128个字符', trigger: 'blur' }],
certificateValidity: [{ required: true, message: '请选择身份证有效期', trigger: 'change' }],
urgencyPhone: [{ max: 30, message: '长度不超过30个字符', trigger: 'blur' }]
+ },
+ // 新增模式的简化验证规则(仅验证核心字段)
+ addRules: {
+ empName: [{ required: true, message: '请输入姓名', trigger: 'blur' },
+ { min: 2, max: 50, message: this.$t('rules.noMoreThan50'), trigger: 'blur' }],
+ empNumb: [{ required: true, message: '请输入员工编号', trigger: 'blur' },
+ { min: 2, max: 20, message: this.$t('rules.noMoreThan20'), trigger: 'blur' }],
+ certificateNumb: [{ required: true, message: '请输入身份证号', trigger: 'blur' }]
},
gbdaRules: {
dimissionType: [{ required: true, message: '请选择离职类型', trigger: 'change' }],
@@ -1914,29 +1918,24 @@
this.showXzyg(1)
},
putEmpBase(formName) {
+ // 根据新增/编辑模式使用不同的验证规则
+ const validateRules = this.isAdd ? this.addRules : this.rules
this.$refs[formName].validate((valid) => {
if (valid) {
this.submitEmpInfo()
- this.fetch({
- ...this.queryParams,
- ...this.sort
- })
- this.cleanEmpBase()
- this.showXzyg()
+ // 刷新、清空、关闭操作已移至 submitEmpInfo 的成功回调中
}
- })
+ }, validateRules)
},
putEmpBaseContinue(formName) {
+ // 根据新增/编辑模式使用不同的验证规则
+ const validateRules = this.isAdd ? this.addRules : this.rules
this.$refs[formName].validate((valid) => {
if (valid) {
- this.submitEmpInfo()
- this.cleanEmpBase()
- this.fetch({
- ...this.queryParams,
- ...this.sort
- })
+ // 传入 true 表示保存并继续新增,不关闭对话框
+ this.submitEmpInfo(true)
}
- })
+ }, validateRules)
},
delEmp() {
var selection = this.$refs.multipleTable.store.states.selection
@@ -2347,9 +2346,25 @@
getDateString() {
return dateToString(new Date())
},
- submitEmpInfo() {
+ submitEmpInfo(continueAdd = false) {
if (this.isAdd) {
this.$post('hr/empBaseInfo/addInEmp', { ...this.empBaseInfoForm }).then((r) => {
+ this.$message({
+ message: this.$t('tips.addSuccess'),
+ type: 'success'
+ })
+ // 刷新列表
+ this.fetch({
+ ...this.queryParams,
+ ...this.sort
+ })
+ // 清空表单
+ this.cleanEmpBase()
+ // 如果不是继续新增,则关闭对话框
+ if (!continueAdd) {
+ this.showXzyg()
+ }
+ // 处理员工已存在的情况
if (r.data != null) {
if (r.data.data.empStatus === '0') {
this.$confirm('该员工已存在,是否修改?', '提示', {
@@ -2398,12 +2413,6 @@
remark: ''
}
this.dialogShowDkda = true
- // this.$post('hr/empOpenArchives', { ...this.openArchivesForm }).then(() => {
- // this.$message({
- // message: this.$t('员工档案打开成功'),
- // type: 'success'
- // })
- // })
})
}
}
@@ -2416,6 +2425,11 @@
})
this.$emit('success')
this.cleanEmpBase()
+ this.fetch({
+ ...this.queryParams,
+ ...this.sort
+ })
+ this.showXzyg()
})
}
},
--
Gitblit v1.8.0