Vue ElementUI Axios 前后端案例(day01) 之Vue
<template>
<el-form :model="ruleForm" :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm">
<el-form-item label="用户名" prop="username">
<el-input v-model="ruleForm.username"></el-input>
</el-form-item>
<el-form-item label="密码" prop="password">
<el-input type="password" v-model="ruleForm.password" autocomplete="off"></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="submitForm('ruleForm')">登录</el-button>
<el-button @click="resetForm('ruleForm')">重置</el-button>
</el-form-item>
</el-form>
</template>
<script>
export default {
data() {
return {
ruleForm: {
username: '',
password: ''
},
rules: {
username: [
{ required: true, message: '请输入用户名', trigger: 'blur' },
{ min: 3, max: 10, message: '长度在 3 到 10 个字符', trigger: 'blur' }
],
password: [
{ required: true, message: '请输入密码', trigger: 'blur' },
{ min: 6, max: 15, message: '长度在 6 到 15 个字符', trigger: 'blur' }
]
}
};
},
methods: {
submitForm(formName) {
this.$refs[formName].validate((valid) => {
if (valid) {
// 使用Axios发送POST请求
axios.post('/api/login', this.ruleForm)
.then(response => {
console.log(response.data);
// 处理登录成功的逻辑,例如保存token和跳转到首页
})
.catch(error => {
console.error(error);
// 处理登录失败的逻辑
});
} else {
console.log('error submit!!');
return false;
}
});
},
resetForm(formName) {
this.$refs[formName].resetFields();
}
}
}
</script>
这个代码实例展示了如何使用Vue.js结合Element UI和Axios来创建一个登录表单,并在用户点击登录按钮时发送POST请求到后端。同时,它也展示了如何使用Vue的响应式数据绑定和Element UI的表单验证功能。这个例子是基于Vue和Element UI的基础用法,并且假设已经有一个后端API /api/login
来处理登录请求。
评论已关闭