https://github.com/LeoHuiyi/leo-vue-validator
一个基于vue2异步的表单验证组件
https://github.com/LeoHuiyi/leo-vue-validator
Last synced: 7 months ago
JSON representation
一个基于vue2异步的表单验证组件
- Host: GitHub
- URL: https://github.com/LeoHuiyi/leo-vue-validator
- Owner: LeoHuiyi
- Created: 2016-12-05T09:07:08.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2017-01-09T06:18:18.000Z (almost 9 years ago)
- Last Synced: 2024-07-18T07:51:15.362Z (over 1 year ago)
- Language: JavaScript
- Homepage:
- Size: 1.01 MB
- Stars: 24
- Watchers: 6
- Forks: 13
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-vue - leo-vue-validator - vue-validator?style=social) - 异步的表单验证组件 (实用库)
- awesome-github-vue - leo-vue-validator - 异步的表单验证组件 (实用库)
- awesome-github-vue - leo-vue-validator - 异步的表单验证组件 (实用库)
- awesome - leo-vue-validator - 异步的表单验证组件 (实用库)
README
leo-vue-validator
============###一个异步的表单验证组件: 只变动数据,能适配各种UI
###update:添加删除不使用removeField 报错提示;验证方式:all 全部验证,first:只验证到第一个错误项, 添加resetCb回调, 表单验证时点击reset中断信息,添加errorCb回调, 表单验证时error中断信息
[demo在线链接](https://leohuiyi.github.io/leo-vue-validator/index.html)
[demo下载地址](https://github.com/LeoHuiyi/leo-vue-validator/tree/gh-pages)
##例子
```vue
leo-vue-validator例子
注意事项:必须先点击初始化按钮或者调用(initForm接口)才能验证
状态参数(state): 0: 没有验证过, 1: 通过, 2: 不通过, 3: 验证中
自定义回调:
1.必须要设置item.state = 1才能验证下面的事项
2.必须调用回调参数cb()验证才开始
改变forms中value的值 都会进行验证
表单1(动态添加表单)
item{{index}}:
删除
删除(不使用removeField 报错,初始化后))
状态:{{item.state}} 提示:{{item.msg}}
初始化
添加
重置
提交(全部验证)
提交(验证到第一个错误项)
表单2
没有验证 :
状态:{{form2[1]['state']}} 提示:{{form2[1]['msg']}}
手机号 :
状态:{{form2[0]['state']}} 提示:{{form2[0]['msg']}}
异步验证整组验证 :
(obj形式 失去焦点验证 password: 123456)
状态:{{form2[2]['state']}} 提示:{{form2[2]['msg']}}
异步验证整组验证(array形式 失去焦点验证) :
状态:{{form2[3]['state']}} 提示:{{form2[3]['msg']}}
初始化
重置
提交(全部验证)
提交(验证到第一个错误项)
import validator from './components/validator/validator'
function leoAlert(data) {
setTimeout(() => {
alert(JSON.stringify(data, null, 4))
})
}export default {
name: 'app',
components: {
'leo-validator': validator,
},
data(){
return {
form1: [
{
key: 'formKey1',
value: '',
rules: [
{
rule: 'required', tip: '请输入活动名称',
},
{
rule: 'isCode', tip: '邮政编码不正确(leo)'
}
],
state: 0,
msg: '',
},
{
key: 'formKey2',
value: 'wahahha',
rules(value, rule, item, cb){
item.msg = 'loading'
setTimeout(() => {
cb((newVal, rule, item) => {
item.state = 1//1才能成功
item.msg = '成功'
})
}, 1000)
},
state: 0,
msg: '',
}
],
form2: [
{
key: 'form2Item1',
value: '',
rules: [
{
rule: 'required', tip: '不能为空',
},
{
rule: 'isPhone', tip: '手机号码格式不对'
},
],
state: 0,
msg: '',
},
{
key: 'form2Item2',
value: '',
state: 0,
msg: '',
},
{
key: 'form2Item3',
value: {
user: 'leo',
password: ''
},
rules: [
{
rule(value, rule, item, cb, index) {
if(value.user === '') {
item.msg = 'user不能为空'
item.state = 2
cb()
return
}
item.msg = 'user验证中'
setTimeout(() => {
cb((newVal, rule, item) => {
if(newVal.user.length > 6) {
item.state = 2
item.msg = 'user不正确'
}else {
item.state = 1
item.msg = 'user验证成功'
}
})
}, 1000)
// throw new Error('error')
},
},
{
rule(value, rule, item, cb, index) {
item.msg = 'password验证中'
setTimeout(() => {
cb((newVal, rule, item) => {
if(newVal.password == 123456) {
item.state = 1
item.msg = 'password验证成功'
}else {
item.state = 2
item.msg = 'password不正确'
}
})
}, 1000)
},
},
],
errorCb(e, item, i){
leoAlert(e.name)
console.log(e, item, i)
},
state: 0,
msg: '',
deep: true//对象的必须深度监听
},
{
key: 'form2Item4',
value: ['leo', 'leoWa'],
rules: [
{
rule(value, rule, item, cb, index) {
if(value[0] === '' || value[1] === '') {
item.msg = 'input都不能为空'
item.state = 2
cb()
return
}
item.state = 3
item.msg = '验证中'
item.timerId = setTimeout(() => {
item.timerId = null
cb((newVal, rule, item) => {
if(newVal[0] == newVal[1]) {
item.state = 1
item.msg = ''
}else {
item.state = 2
item.msg = '第一项和第二项不相等'
}
})
}, 300)
}
},
],
resetCb(item, i){
if(item.timerId){ //clearTimeout
clearTimeout(item.timerId)
item.timerId = null
}
},
state: 0,
msg: ''
},
],
tagOptions1: {
'class': 'form1',
'style': {paddingLeft: '10px'}
},
tagOptions2: {
'class': {form2: true},
'style': {paddingLeft: '10px'}
}
}
},
methods: {
initForm1(){
this.$refs.leoForm1.initForm()
},
initForm(){
this.$refs.leoForm.initForm()
},
reset1(){
this.$refs.leoForm1.resetFields()
},
submit1(op){
this.$refs.leoForm1.validate(op).then((result) => {
leoAlert(result)
}).catch((result) => {
console.log('catch')
leoAlert(result)
})
console.log(this.$refs.leoForm1.getFormData())
},
reset(){
this.$refs.leoForm.resetFields()
},
submit(op){
this.$refs.leoForm.validate(op).then((result) => {
leoAlert(result)
}).catch((result) => {
console.log('catch')
leoAlert(result)
})
console.log(this.$refs.leoForm.getFormData())
},
add(){
this.form1.push({
key: `formKey${this.form1.length + 1}`,
value: '',
rules: [
{
rule: (value, rule, item, cb) => {
if('leo好帅' === value) {
item.state = 1
item.msg = ''
}else {
item.state = 2
item.msg = '请输入leo好帅'
}
cb()
}
}
],
state: 0,
msg: '',
})
},
deleteItem(item){
this.$refs.leoForm.removeField(item)
},
deleteItem1(item){
const forms = this.form1
const index = forms.indexOf(item)
if(index > -1) {
forms.splice(index, 1)
}
}
}
}```
### options
Property | Type | Default | Description
:-----------------------|:--------------|:--------------|:--------------------------------
forms | Array | [] | 表单验证数据选项
form.key | String | '' | key(必须唯一)
form.value | String | '' | value
form.rules | Array or Object | '' | rules
form.state | String | '' | 0: 没有验证过, 1: 通过, 2: 不通过, 3: 验证中
form.msg | String | '' | 提示信息
form.tip | String | '' | 替代默认规则的提示信息
form.deep | Boolean | '' | 深度watch
form.resetCb | Function | '' | reset回调
form.errorCb | Function | '' | errorCb回调
tag | String | 'span' | leo-validator tag
tagOptions | Object | 无 | leo-validator tagOptions### Method
============
在$refs上调用(具体看例子)
添加可以直接在forms数组上添加(要按vue的数组方法)!
删除只能调用removeField接口!Name | Description
:-----------------------|:--------------|
initForm | 初始化(必须首次验证前调用 才能开始验证)
resetFields | 重置
validate | 验证(是个Promise,具体可以看例子, 参数:all 全部验证,first:只验证到第一个错误项)
removeField | 删除(删除item 可以传入数组)
getFormData | 取得FormData# License
MIT Licensed. Copyright (c) leoHuiyi 2016.