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;
        }
    });
}

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

相关推荐
Mike_jia41 分钟前
uuWAF:开源Web应用防火墙新标杆——从工业级防护到智能防御实战解析
前端
掘金安东尼1 小时前
Chrome 17 岁了——我们的浏览器简史
前端·javascript·github
袁煦丞1 小时前
群晖NAS FTP远程文件仓库全球访问:cpolar内网穿透实验室第524个成功挑战
前端·程序员·远程工作
前端小巷子1 小时前
JS 打造动态表格
前端·javascript·面试
excel1 小时前
从卷积到全连接:用示例理解 CNN 的分层
前端
UNbuff_01 小时前
HTML 各种事件的使用说明书
前端·html
Mr. Cao code1 小时前
探索OpenResty:高性能Web开发利器
linux·运维·服务器·前端·nginx·ubuntu·openresty
百思可瑞教育2 小时前
ActiveMQ、RocketMQ、RabbitMQ、Kafka 的全面对比分析
vue.js·分布式·rabbitmq·rocketmq·activemq·北京百思可瑞教育·百思可瑞教育
li35749 小时前
将已有 Vue 项目通过 Electron 打包为桌面客户端的完整步骤
前端·vue.js·electron
Icoolkj9 小时前
VuePress 与 VitePress 深度对比:特性、差异与选型指南
前端·javascript·vue.js