vue+elementUI用户修改密码的前端验证

用户登录后修改密码,密码需要一定的验证规则。旧密码后端验证是否正确;前端验证新密码的规范性,新密码规范为:6-16位,至少含数字/字母/特殊字符中的两种;确认密码只需要验证与新密码是否一致;

弹窗结构

javascript 复制代码
<el-dialog title="修改密码"
           :visible.sync="passDlgVisible"
           @close="passDlgClose"
           width="400px">
    <el-form :model="passForm"
             ref="passRef"
             :rules="passRules"
             hide-required-asterisk
             label-width="70px"
             size="small">
        <el-form-item label="旧密码" prop="oldPassword">
            <el-input v-model="passForm.oldPassword" show-password></el-input>
        </el-form-item>
        <el-form-item label="新密码" prop="newPassword">
            <el-input v-model="passForm.newPassword" show-password></el-input>
        </el-form-item>
        <el-form-item label="确认密码" prop="confirmPassword">
            <el-input v-model="passForm.confirmPassword" show-password></el-input>
        </el-form-item>
    </el-form>
    <span slot="footer">
            <el-button @click="passDlgVisible=false" size="small">取消</el-button>
            <el-button @click="passSave" type="primary" size="small">确认</el-button>
        </span>
</el-dialog>

form验证规则

javascript 复制代码
passRules: {
	oldPassword:[{required: true, message: '请输入旧密码', trigger: 'blur'}],
    newPassword:[{validator: this.validNewPass, trigger: 'blur'}],
    confirmPassword:[{validator: this.validConfirmPass, trigger: 'blur'}]
}

验证函数

javascript 复制代码
/**
 * 验证新密码
 */
validNewPass(rule, value, callback) {
    let reg = /(?!^(\d+|[a-zA-Z]+|[~!@#$%^&*?]+)$)^[\w~!@#$%^&*?]{6,16}$/
    if (value === '') {
        callback(new Error('请输入新密码'));
    } else if (!reg.test(value)) {
        callback(new Error('6-16位,至少含数字/字母/特殊字符中的两种'))
    } else {
        if (this.passForm.confirmPassword !== '') {
            this.$refs.passRef.validateField('confirmPassword');
        }
        callback();
    }
},

/**
 * 验证确认密码
 */
validConfirmPass(rule, value, callback) {
    if (value === '') {
        callback(new Error('请再次输入密码'));
    } else if (value !== this.passForm.newPassword) {
        callback(new Error('两次输入密码不一致!'));
    } else {
        callback();
    }
}

弹窗关闭后清空字段和验证

javascript 复制代码
/**
 * 弹窗关闭事件
 */
passDlgClose() {
    this.passForm = {
        oldPassword: '',
        newPassword: '',
        confirmPassword: ''
    }
    this.$refs.passRef.clearValidate();
}

提交表单

javascript 复制代码
passSave() {
    this.$refs.passRef.validate((valid) => {
        if (valid) {
            this.passForm.userName = this.userName
            api.user.editPass(this.passForm).then(res => {
                this.passDlgVisible = false;
            })
        } else {
            return false;
        }
    });
}

这就是修改密码的全部流程啦。。。。有问题评论区答复。。。。能解决的就答复,不能解决的自己百度哈。。。。

相关推荐
科普瑞传感仪器4 分钟前
从轴孔装配到屏幕贴合:六维力感知的机器人柔性对位应用详解
前端·javascript·数据库·人工智能·机器人·自动化·无人机
n***F87510 分钟前
SpringMVC 请求参数接收
前端·javascript·算法
wordbaby21 分钟前
搞不懂 px、dpi 和 dp?看这一篇就够了:图解 RN 屏幕适配逻辑
前端
程序员爱钓鱼23 分钟前
使用 Node.js 批量导入多语言标签到 Strapi
前端·node.js·trae
鱼樱前端24 分钟前
uni-app开发app之前提须知(IOS/安卓)
前端·uni-app
V***u45324 分钟前
【学术会议论文投稿】Spring Boot实战:零基础打造你的Web应用新纪元
前端·spring boot·后端
TechMasterPlus25 分钟前
VScode如何调试javascript文件
javascript·ide·vscode
i听风逝夜1 小时前
Web 3D地球实时统计访问来源
前端·后端
iMonster1 小时前
React 组件的组合模式之道 (Composition Pattern)
前端
北辰alk1 小时前
Vue 中 nextTick 的魔法:为什么它能拿到更新后的 DOM?
vue.js