利用elementui
1.安装$ npm i element-ui
2.开发时依赖 : 开发环境所需要的依赖 -> devDependencies
运行时依赖: 项目上线依然需要的依赖 -> dependencies
安装开环境 npm install element-ui -D
安装运行环境npm install element-ui -s
3.在main.js中对ElementUI进行注册
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
Vue.use(ElementUI);
代码:
<template>
<div id="app">
<!-- 卡片组件 -->
<el-card class='login-card'>
<!-- 登录表单 -->
<el-form style="margin-top: 50px" :model='loginForm' :rules="loginRules">
<el-form-item prop='mobile'>
<el-input placeholder="请输入手机号" v-model="loginForm.mobile"></el-input>
</el-form-item>
<el-form-item prop='password'>
<el-input placeholder="请输入密码" v-model="loginForm.password"></el-input>
</el-form-item >
<el-form-item>
<el-button type="primary" style="width: 100%">登录</el-button>
</el-form-item>
</el-form>
</el-card>
</div>
</template>
<script>
export default {
name: 'App',
components: {
}
data () {
// 定义表单数据对象
return {
loginForm: {
mobile: '',
password: ''
}
},
loginRules: {
mobile: [{ required: true, message: '手机号不能为空', trigger: 'blur' },
{ pattern: /^1[3-9]\d{9}$/, message: '请输入正确的手机号', trigger: 'blur' }],
password: [{ required: true, message: '密码不能为空', trigger: 'blur' }, {
min: 6, max: 16, message: '密码应为6-16位的长度', trigger: 'blur'
}]
}
}
}
</script>
<style>
#app {
width: 100%;
height: 100vh;
background-color: pink;
display: flex;
justify-content: center;
align-items: center;
}
.login-card {
width: 440px;
height: 300px;
}
</style>
| 规则 | 说明 |
|---|---|
| required | 如果为true,表示该字段为必填 |
| message | 当不满足设置的规则时的提示信息 |
| pattern | 正则表达式,通过正则验证值 |
| min | 当值为字符串时,min表示字符串的最小长度,当值为数字时,min表示数字的最小值 |
| max | 当值为字符串时,max表示字符串的最大长度,当值为数字时,max表示数字的最大值 |
| trigger | 校验的触发方式,change(值改变) / blur (失去焦点)两种, |
| validator | 如果配置型的校验规则不满足你的需求,你可以通过自定义函数来完成校验 |
校验规则的格式
***{ key(字段名): value(校验规则) => [{}] }***
根据以上的规则,针对当前表单完成如下要求
**手机号** 1.必填 2.手机号格式校验 3. 失去焦点校验
**密码** 1.必填 2.6-16位长度 3. 失去焦点校验
自定义校验规则:
validator是一个函数, 其中有三个参数 (rule(当前规则),value(当前值),callback(回调函数))
var func = function (rule, value, callback) {
// 根据value进行进行校验
// 如果一切ok
// 直接执行callback
callback() // 一切ok 请继续
// 如果不ok
callback(new Error("错误信息"))
}
// 自定义校验函数
const checkMobile = function (rule, value, callback) {
value.charAt(2) === '9' ? callback() : callback(new Error('第三位手机号必须是9'))
}
mobile: [
{ required: true, message: '手机号不能为空', trigger: 'blur' },
{ pattern: /^1[3-9]\d{9}$/, message: '请输入正确的手机号', trigger: 'blur' }, {
trigger: 'blur',
validator: checkMobile
}],