使用ES6编写的一个类似laravel的js验证模块.

使用ES6编写的一个类似laravel的js验证模块.

PHP小彩虹2021-08-22 5:43:23280A+A-

使用ES6编写的一个类似laravel的js验证模块.

安装

$ npm install validation-es6

基本用法

import {
    Validator
} from './node_modules/validation-es6/validator.js';

let rules = {
  username: 'required|min:5',
  password: 'required|confirmed|min:6|max:16',
}

let data = {
  username: 'test',
  password: '123456',
}

let v = new Validator(data, rules);

if (v.fails()) {
    console.log(v.messages());
}

定义验证规则

  • "|" 分隔的字符串形式
let rules = {
  username: 'required|min:5',
  password: 'required|confirmed|min:6|max:16',
  email: 'email'
}
  • 数组形式
let rules = {
  username: ['required', 'min:5'],
  password: ['required', ['confirmed'], ['min:6'], ['max:16'],
  email: ['required', 'email']
}

其他

  • 自定义错误消息、属性别名、验证函数

    在消息字符串用使用:attribute 作为属性名占位符。

    //错误消息
    let customMessages = {
        accepted: ":attribute 必须接受",
    };
    
    //属性别名
    let attribute = {
        "item": "条款"
    }
    
    //使用回调函数定义错误消息
    let replacers = {
        accepted: function (message, attribute, rule,parameters) {
            return message;
        }
    },
    
    let v = new Validator(data, rules, customMessages, attribute, replacers);
    
    //注册自定义验证函数
    v.register('upper', (attribute, value, parameters) => {
        return value.toUpperCase() == "NAME";
    }, ":attribute = :value 不对");
    
    if (v.fails()) {
        console.log(v.messages());
    }
    

License

MIT

点击这里复制本文地址 以上内容由权冠洲的博客整理呈现,请务必在转载分享时注明本文地址!如对内容有疑问,请联系我们,谢谢!

支持Ctrl+Enter提交

联系我们| 本站介绍| 留言建议 | 交换友链 | 域名展示
本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除

权冠洲的博客 © All Rights Reserved.  Copyright quanguanzhou.top All Rights Reserved
苏公网安备 32030302000848号   苏ICP备20033101号-1
本网站由 提供CDN/云存储服务

联系我们