拿来即用修改密码功能

javascript 复制代码
<template>
	<div>
		<!-- 重置密码 -->
		<el-dialog
			title="修改密码"
			v-model="state.resetPwdDialogVisible"
			:showClose="state.firstLogin !== 1"
			width="550px"
			@close="onCancel"
			:close-on-click-modal="false"
		>
			<el-form :model="state.resetPwdForm" status-icon :rules="state.resetPwdRules" ref="pwdForm" label-width="100px">
				<el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
					<el-form-item label="新密码" prop="pwd_new1">
						<el-input
							placeholder="请输入新密码"
							type="password"
							v-model="state.resetPwdForm.pwd_new1"
							autocomplete="new-password"
							show-password
							clearable
						>
						</el-input>
					</el-form-item>
				</el-col>
				<el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
					<el-form-item label="确认新密码" prop="pwd_new2">
						<el-input
							placeholder="请再次输入新密码"
							type="password"
							v-model="state.resetPwdForm.pwd_new2"
							autocomplete="new-password"
							show-password
							clearable
						>
						</el-input>
					</el-form-item>
				</el-col>
			</el-form>
			<template #footer>
				<span class="dialog-footer">
					<el-button @click="onCancel" size="default">取消</el-button>
					<el-button v-throttle type="primary" @click="onSubmit" size="default">确定</el-button>
				</span>
			</template>
		</el-dialog>
	</div>
</template>

<script setup name="layoutBreadcrumbUser">
import { updatePwd } from '/@/api/login.js';

const pwdForm = ref(null);

const validatePass = (rule, value, callback) => {
	if (value === '') {
		callback(new Error('请输入密码'));
	} else {
		if (state.resetPwdForm.pwd_new2 !== '') {
			pwdForm.value.validateField('pwd_new2');
		}
		callback();
	}
};
const validatePass2 = (rule, value, callback) => {
	if (value === '') {
		callback(new Error('请再次输入密码'));
	} else if (value !== state.resetPwdForm.pwd_new1) {
		callback(new Error('两次输入密码不一致!'));
	} else {
		callback();
	}
};
const state = reactive({
	resetPwdDialogVisible: false, // 修改密码
	resetPwdForm: {
		pwd_new1: '',
		pwd_new2: '',
	},
	resetPwdRules: {
		pwd_new1: [
			{
				required: true,
				trigger: 'blur',
				message: '请输入6~20位不含有中文的密码',
				pattern: /^[^\u4e00-\u9fa5 ]{6,20}$/,
			},
			{ validator: validatePass, trigger: 'blur' },
		],
		pwd_new2: [
			{
				required: true,
				trigger: 'blur',
				message: '请输入6~20位不含有中文的密码',
				pattern: /^[^\u4e00-\u9fa5 ]{6,20}$/,
			},
			{ validator: validatePass2, trigger: 'blur' },
		],
	}
});

// 取消
const onCancel = () => {
	state.resetPwdDialogVisible = false;
	// 清除验证
	pwdForm.value.resetFields();
};

// 修改密码保存
const onSubmit = () => {
	if (!pwdForm) return;
	pwdForm.value.validate((valid) => {
		if (valid) {
			toSavePwd();
		} else {
			return false;
		}
	});
};

const toSavePwd = () => {
	updatePwd(state.resetPwdForm)
		.then((res) => {
			if (res.data.code === 1) {
				ElMessage.success('密码修改成功');
				state.resetPwdDialogVisible = false;
			}
		})
		.catch((error) => {
			return;
		});
};

// 页面加载时
onMounted(() => {});
</script>
相关推荐
你挚爱的强哥3 小时前
✅✅✅【Vue.js】sd.js基于jQuery Ajax最新原生完整版for凯哥API版本
javascript·vue.js·jquery
susu10830189113 小时前
vue3中父div设置display flex,2个子div重叠
前端·javascript·vue.js
天天进步20156 小时前
Vue+Springboot用Websocket实现协同编辑
vue.js·spring boot·websocket
疯狂的沙粒6 小时前
如何在Vue项目中应用TypeScript?应该注意那些点?
前端·vue.js·typescript
小镇程序员6 小时前
vue2 src_Todolist全局总线事件版本
前端·javascript·vue.js
想自律的露西西★7 小时前
用el-scrollbar实现滚动条,拖动滚动条可以滚动,但是通过鼠标滑轮却无效
前端·javascript·css·vue.js·elementui·前端框架·html5
白墨阳8 小时前
vue3:瀑布流
前端·javascript·vue.js
程序媛-徐师姐9 小时前
Java 基于SpringBoot+vue框架的老年医疗保健网站
java·vue.js·spring boot·老年医疗保健·老年 医疗保健
余道各努力,千里自同风10 小时前
前端 vue 如何区分开发环境
前端·javascript·vue.js
PandaCave10 小时前
vue工程运行、构建、引用环境参数学习记录
javascript·vue.js·学习