关于el-form表单校验明明没问题, 但是await formRef.value.validate()始终不通过

问题描述:

我是vue3+vite+ts, 添加用户没问题, 修改用户的表单校验有问题, 表单符合规则但是await formRef.value.validate()始终不通过
 

html结构:

<el-drawer v-model="drawer" :title="userParams.id?'修改用户':'添加用户'">
    <el-form ref="formRef" :model="userParams" :rules="rules">
        <el-form-item prop="username" label="用户姓名">
            <el-input v-model="userParams.username" type="text"></el-input>
        </el-form-item>
        <el-form-item prop="name" label="用户昵称">
            <el-input v-model="userParams.name" type="text"></el-input>
        </el-form-item>
        <el-form-item prop="password" v-show="!userParams.id" label="用户密码">
            <el-input v-model="userParams.password" type="text"></el-input>
        </el-form-item>
    </el-form>
    <template #footer>
        <el-button @click="cancelClick">取消</el-button>
        <el-button type="primary" @click="confirmClick">确定</el-button>
    </template>
</el-drawer>

js代码:

import { onMounted, ref ,nextTick, reactive} from 'vue'
import {reqUserInfo , reqAddOrUpdateUser} from '../../../api/acl/user'
import { SetRoleData, UserResponseData, Records, User, AllRoleResponseData, AllRole } from '../../../api/acl/user/type.ts';
import { ElMessage } from 'element-plus';
import { ResponseData } from '../../../api/user/type.ts';

let drawer = ref(false) //控制抽屉的显示与隐藏
let userParams = reactive<User>({
    username:'',
    name:'',
    password:''
})
let formRef = ref()

// 自定义表单校验username和name
const validateUserNameOrName = (rule: any, value: any, callBack: any)=>{
    const usernameRegex = /^(?!\d+$)(?![a-zA-Z]+$).+$/;  
    if (!usernameRegex.test(value) && value !== '') {  
        callBack(new Error('不能仅由字母或数字组成'));  
    }   
    else if(value == 'admin'){
        callBack(new Error('用户名已存在'));
    }else{
        callBack();
    }
}
// 自定义表单校验password
const validateUserPassword = (rule: any, value: any, callBack: any)=>{
    const passwordRegex = /^(?=.*[a-zA-Z])(?=.*\d).+$/;
    if (!passwordRegex.test(value)) {  
        return callBack(new Error('密码至少包含字母和数字'));  
    }else{
        callBack();
    }
}

// 表单校验规则属性
const rules = {
    username:[
        {required:true,message:'请输入用户名',trigger:'blur'},
        {min:2,max:13,message:'用户长度请控制在2-13位',trigger:'blur'},
        {trigger:'blur',validator:validateUserNameOrName}
    ],
    name:[
        {required:true,message:'请输入用户昵称',trigger:'blur'},
        {min:2,max:13,message:'用户长度请控制在2-13位',trigger:'blur'},
        {trigger:'blur',validator:validateUserNameOrName}
    ],
    password:[
        {required:true,message:'请输入密码',trigger:'blur'},
        {min:6,max:13,message:'用户长度请控制在6-13位',trigger:'blur'},
        {trigger:'blur',validator:validateUserPassword}
    ]
}


// 获取已有用户信息
const getHasUser =async()=>{
    let res:UserResponseData = await reqUserInfo(currentPage.value , pageSize.value)
    if(res.code ==200){
        total.value = res.data.total
        userArr.value = res.data.records
    }
}
// 添加用户按钮
const addUser = async()=>{
    // 每次进来清空上次收集表单数据
    Object.assign(userParams,
        {
            id:'',
            username:'',
            name:'',
            password:''
        }
    )
    // 清理之前的校验信息
    nextTick(()=>{
        formRef.value.clearValidate('username');
        formRef.value.clearValidate('name');
        formRef.value.clearValidate('password');
    })
    
    drawer.value = true
}

// 编辑按钮修改用户信息
const updateUser =(row:User)=>{
    // 清理之前的校验信息
    nextTick(()=>{
        formRef.value.clearValidate('username');
        formRef.value.clearValidate('name');
    })
    drawer.value = true
     // 每次进来绑定当前用户对象row的表单数据
    Object.assign(userParams,row)
    console.log(formRef);
    
    
}

// 抽屉的取消按钮
const cancelClick = ()=>{
    drawer.value = false
}

// 抽屉的确定按钮
const confirmClick = async() =>{
    try {
        await formRef.value.validate()
        drawer.value = false
        let res:any = await reqAddOrUpdateUser(userParams)
        if(res.code == 200 ){
            ElMessage({
                type:'success',
                message:userParams.id?"修改成功":"添加成功"
            })
            drawer.value = false
            getHasUser()
        }else{
            drawer.value = false
            ElMessage({
                type:'error',
                message:userParams.id?"修改失败":"添加失败"
            })
        }
    } catch (error) {
        ElMessage({
                type:'error',
                message:"表单校验不通过"
            })
    }
    
    
}

onMounted(()=>{
    getHasUser()
})

破案了:

html结构中v-show应该改为v-if, 至于他们俩的区别我想就不多说了, 点击修改按钮的时候row中的password赋给了userParams(这个值可能是不符合你的表单规范的), 由于v-show的原理是控制display:none的, 所以其实做修改用户的表单校验时候不仅校验了用户名和昵称,也校验了password(即使他被我隐藏了), 而v-if销毁了

<el-form-item prop="password" v-if="!userParams.id" label="用户密码">
    <el-input v-model="userParams.password" type="text"></el-input>
</el-form-item>

这个item组件就不会引发prop="password"这个字段的校验

在 Vue 3 中,你可以使用 `async/await` 或者 `Promise` 来处理多个表单校验。 使用 `async/await` 的方式: ```javascript async function validateForms() { try { await formRef.value.validate(); // 第一个表单校验成功后执行的逻辑 await formRef1.value.validate(); // 第二个表单校验成功后执行的逻辑 // 其他逻辑... } catch (error) { // 处理校验失败的情况 } } ``` 在上面的例子中,我们使用了 `async` 函数来创建一个异步函数 `validateForms`。在 `try` 块中,我们使用 `await` 关键字依次调用了 `formRef.value.validate()` 和 `formRef1.value.validate()` 方法进行表单校验。如果校验成功,就可以在每个 `await` 后面继续编写相应的逻辑。如果任何一个校验失败,代码将会跳转到 `catch` 块中进行错误处理。 如果你更喜欢使用 `Promise` 的方式: ```javascript formRef.value.validate() .then(() => { // 第一个表单校验成功后执行的逻辑 return formRef1.value.validate(); }) .then(() => { // 第二个表单校验成功后执行的逻辑 // 其他逻辑... }) .catch(error => { // 处理校验失败的情况 }); ``` 上面的代码中,我们使用了 `then` 方法来处理每个表单校验的成功回调,使用 `catch` 方法来处理校验失败的情况。每个 `then` 方法返回一个 `Promise`,使得我们可以通过链式调用来依次执行多个表单校验。 无论你选择使用 `async/await` 还是 `Promise`,都可以根据自己的喜好和项目需求来选择适合的方式。请确保在使用前先正确引入并初始化表单引用(`formRef` 和 `formRef1`)。 希望对你有所帮助!如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值