<template> <div style="display: inline-block;"> <el-dialog :visible.sync="dialog" :close-on-click-modal="false" :before-close="cancel" :title="title" append-to-body width="475px" @close="cancel"> <el-form ref="form" :model="form" :rules="rules" size="small" label-width="88px"> <el-form-item label="新邮箱" prop="email"> <el-input v-model="form.email" auto-complete="on" style="width: 200px;" /> <el-button :loading="codeLoading" :disabled="isDisabled" size="small" @click="sendCode">{{ buttonName }}</el-button> </el-form-item> <el-form-item label="验证码" prop="code"> <el-input v-model="form.code" style="width: 320px;" /> </el-form-item> <el-form-item label="当前密码" prop="pass"> <el-input v-model="form.pass" type="password" style="width: 320px;" /> </el-form-item> </el-form> <div slot="footer" class="dialog-footer"> <el-button type="text" @click="cancel">取消</el-button> <el-button :loading="loading" type="primary" @click="doSubmit">确认</el-button> </div> </el-dialog> </div> </template> <script> import store from '@/store' import { validEmail } from '@/utils/validate' import { updateEmail } from '@/api/system/user' import { resetEmail } from '@/api/system/code' export default { props: { email: { type: String, required: true } }, data() { const validMail = (rule, value, callback) => { if (value === '' || value === null) { callback(new Error('新邮箱不能为空')) } else if (value === this.email) { callback(new Error('新邮箱不能与旧邮箱相同')) } else if (validEmail(value)) { callback() } else { callback(new Error('邮箱格式错误')) } } return { loading: false, dialog: false, title: '修改邮箱', form: { pass: '', email: '', code: '' }, user: { email: '', password: '' }, codeLoading: false, buttonName: '获取验证码', isDisabled: false, time: 60, rules: { pass: [ { required: true, message: '当前密码不能为空', trigger: 'blur' } ], email: [ { required: true, validator: validMail, trigger: 'blur' } ], code: [ { required: true, message: '验证码不能为空', trigger: 'blur' } ] } } }, methods: { cancel() { this.resetForm() }, sendCode() { if (this.form.email && this.form.email !== this.email) { this.codeLoading = true this.buttonName = '验证码发送中' const _this = this resetEmail(this.form.email).then(res => { this.$message({ showClose: true, message: '发送成功,验证码有效期5分钟', type: 'success' }) this.codeLoading = false this.isDisabled = true this.buttonName = this.time-- + '秒后重新发送' this.timer = window.setInterval(function() { _this.buttonName = _this.time + '秒后重新发送' --_this.time if (_this.time < 0) { _this.buttonName = '重新发送' _this.time = 60 _this.isDisabled = false window.clearInterval(_this.timer) } }, 1000) }).catch(err => { this.resetForm() this.codeLoading = false console.log(err.response.data.message) }) } }, doSubmit() { this.$refs['form'].validate((valid) => { if (valid) { this.loading = true updateEmail(this.form).then(res => { this.loading = false this.resetForm() this.$notify({ title: '邮箱修改成功', type: 'success', duration: 1500 }) store.dispatch('GetInfo').then(() => {}) }).catch(err => { this.loading = false console.log(err.response.data.message) }) } else { return false } }) }, resetForm() { this.dialog = false this.$refs['form'].resetFields() window.clearInterval(this.timer) this.time = 60 this.buttonName = '获取验证码' this.isDisabled = false this.form = { pass: '', email: '', code: '' } } } } </script> <style scoped> </style>