【vue插件篇】vue-form-check 表单验证

栏目: 编程语言 · 发布时间: 7年前

// 引用(eg. 在工程的main.js下)
import vueFormCheck from 'vue-form-check'
Vue.use(vueFormCheck)
复制代码

调用

this.$checkForm(current, config)
@params
current 是当前校验对象
config  是校验规则对象

config.alias     别名
config.type      配置项数据类型
config.required  是否必填
config.rule      正则校验
config.depend    先决条件(省事可以在callback里直接判断,推荐写,true校验本项;false不校验本项)
config.callback  灵活校验(rule同时出现,只处理callback,参数是当前值,true校验通过;false校验不通过)

@return object 对象
不通过的话    {alias: '电话', type: 'rule'}   alias是配置的别名,type可以是['type'|'required'|'rule']
校验通过的话  {} 空对象

ps. 验证表单可以写在mixin里,这里简单处理直接写在组件里了
复制代码

Component

// 使用例子
new Vue({
  data() {
    return {
      params: {
        id: '1234',
        person: {
            name: 'jackie',
            age: '27',
            phone: '18266666666',
            home: ['罗湖区田心村']
        }
      }
    }
  },
  methods: {
    submit() {
      //...
      console.log('submit success');
    },
    check() {
      let obj = this.$checkForm(this.params, {
            id: {
              alias: 'id',
              type: 'string'
            },
            // 必填校验
            'person.name': {
                alias: '学校',
                type: 'string',
                required: true
            },
            // 正则校验
            'person.phone': {
                alias: '电话',
                type: 'string',
                rule: /^1[345678][0-9]{9}$/
            },
            // 灵活校验,如数值、日期区间验证
            'person.age': {
                alias: '年龄',
                callback(value) {
                    if (value < 30 && value > 18) {
                        return true;
                    }
                    return false;
                }
            },
            // 先决校验,如果电话等于以下,校验地址信息
            'person.home': {
                alias: '方向',
                type: 'array',
                required: true,
                depend() {
                    if (this.params.person.phone === '18210517463') {
                      return true;
                    }
                    return false;
                }
          }
        });
        const length = Object.keys(obj).length;
        if (length === 0) {
            return this.submit();
        }
        switch (obj.type) {
            case 'type':
                this.$alert(`${obj.alias}的类型定义错误`, '提示');
                break;
            case 'required':
                this.$alert(`${obj.alias}是必填项`, '提示');
                break;
            case 'rule':
                this.$alert(`${obj.alias}的输入不符合规范`, '提示');
                break;
            default:
                break;
        }
    }
  }
});
复制代码

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

C语言名题精选百则技巧篇

C语言名题精选百则技巧篇

冼镜光 / 机械工业出版社 / 2005-7 / 44.00元

《C语言名题精选百则》(技巧篇)收集了100则C语言程序设计题,共分9类。第一类比较简单,主要希望读者了解到《C语言名题精选百则》(技巧篇)的题目、解法与其他书籍之间的差异;第二至六类分别是关于数字、组合数学或离散数学、查找、排序、字符串等方面的题目;第七类列出了一些不太容易归类的题目,如Buffon丢针问题、Dijkstra的三色旗问题等;第八类则收录了一些有趣的、娱乐性的题目,如魔方阵等;第九......一起来看看 《C语言名题精选百则技巧篇》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具