1.前端表单数据验证
① 当填写完用户名和密码后,只要鼠标离开文本框,就会立即对填写的数据进行合法性的校验
② 为表单项添加数据验证的行为,官方文档组件 | Element
- 首先要为el-form 组件通过属性绑定,绑定一个 :rules 的属性,它的值是表单的验证规则对象。
- 验证规定对象 rules在数据行为区域定义
- 数组中每一个对象,都是一个验证规则。例如:
- required为true表示必填
- message 表示错误提示的消息 (不符合该验证规则,就提示该消息)
- trigger 表示触发验证机制,blur 是鼠标失去焦点时触发本次验证行为
- min 表示最小长度
- max 表示最大长度
③ 如上,验证对象有了,验证规则也创建了。还需要将验证规则跟表单的Item项进行绑定。这样才能够触发验证。
- 为Item项指定 prop 属性,属性的值就等于在数据行为区创建的验证规则
- 数据行为区创建的验证规则如下
进行了如上绑定后,就表示 prop="name" 的item项 ,使用的验证规则是行为区域定义的name属性的验证规则做为当前item项文本输入框数据合法性的验证。
④ 步骤总结
- 在el-form 通过属性绑定指定:rules 校验对象
- 在data中 定义校验对象,其中每一个属性,都是一个验证规则。
- 通过prop 为不同的item项绑定不同的验证规则。(注意:prop是加在item里面,不是加在文本框里面)
⑤ 效果图片
⑥ 进入实战,验证登录用户名和密码
<template>
<div class="login_container">
<div class="login_box">
<!-- 头像区域 -->
<div class="avatar_box">
<img src="../assets/logo.png" alt="" />
</div>
<!-- 登录表单区域 -->
<el-form :model="loginForm" :rules="loginFormRules" label-width="0px" class="login_form">
<!-- 用户名 -->
<el-form-item prop="username">
<el-input
v-model="loginForm.username"
prefix-icon="iconfont icon-yonghu"
>
</el-input>
</el-form-item>
<!-- 密码 -->
<el-form-item prop="password">
<el-input
v-model="loginForm.password" type="password"
prefix-icon="iconfont icon-mima"
>
</el-input>
</el-form-item>
<!-- 按钮区域 -->
<el-row justify="end">
<el-form-item class="login_btn">
<el-button type="primary">登录</el-button>
<el-button type="info">重置</el-button>
</el-form-item>
</el-row>
</el-form>
</div>
</div>
</template>
<script>
export default {
data () {
return {
// 这是登录表单的数据绑定对象
loginForm: {
username: '',
password: ''
},
// 这是表单的验证规则对象
loginFormRules: {
// 验证用户名是否合法
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' }
]
}
}
}
}
</script>
<style lang="less" scoped>
.login_container {
background-color: #2b4b6b;
height: 100vh;
}
.login_box {
// 宽450像素
width: 450px;
// 高300像素
height: 300px;
// 背景颜色
background-color: #fff;
// 圆角边框3像素
border-radius: 3px;
// 绝对定位
position: absolute;
// 距离左则50%
left: 50%;
// 上面距离50%
top: 50%;
// 进行位移,并且在横轴上位移-50%,纵轴也位移-50%
transform: translate(-50%, -50%);
.avatar_box {
// 盒子高度130像素
height: 130px;
// 宽度130像素
width: 130px;
// 边框线1像素 实线
border: 1px solid #eee;
// 圆角
border-radius: 50%;
// 内padding
padding: 10px;
// 添加阴影 向外扩散10像素 颜色ddd
box-shadow: 0 0 10px #ddd;
// 绝对定位
position: absolute;
// 距离左则
left: 50%;
// 位移
transform: translate(-50%, -50%);
// 背景
background-color: #fff;
img {
width: 100%;
height: 100%;
border-radius: 50%;
background-color: #eee;
}
}
}
.login_form {
position: absolute;
bottom: 0;
width: 100%;
padding: 0 20px;
box-sizing: border-box;
}
.login_btn {
// 设置弹性布局
display: flex;
// 横轴上尾部对齐
justify-content: flex-end;
}
</style>
以上出自于:【黑马程序员】前端开发之Vue项目实战_Element-UI【配套源码+笔记】_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1x64y1S7S7?p=1