hagim
v1.0.5
Published
a validation lib
Downloads
11
Readme
hagim
a validation lib for browser environment only. https://www.npmjs.com/package/hagim
why
It has been a long time since I have needed to find an easy to use javascript validation lib for browser environments. Every lib I found on github is not suitable for me. So finally I decided to make a new wheel.
The most significant different between Node.js
environment and browser environment is that in the latter, numbers may be represented by a string variable(e.g: if using a Two-Way Data Binding framework). So, validating a number in the browser may be more difficult than in Node.js.
Another different is that there are more logic disjunction cases in browser environment.
installation
To install via npm, run:
npm install hagim
load
To load hagim in node.js:
const Hagim = require('hagim');
design
let hagim = new Hagim(rules)
hagim.validate("value")
It is the basic form of usage of Hagim
.
The rules should be an array, e.g:
[{is: "number"}, {is: "integer"}]
Number
andString
can be judged by the same API- multiple rules can be gathered togather to form a complex judgement
- rules may be treated in a
and
behavior by default, but you can change this by adding a additionaltrue
literal in the rules array - rules can be nested to form a complex judgement
The elements of the array consists of a validator and an operand. e.g is
is the validator and "number"
is the operand.
Each rule will be performed one by one, follow the order of they are in the array. If one rule fails, by default the whole process will be failed.
let hagim = new Hagim([{is: "empty"}, {is: "number"}, {is: "email"}, true])
hagim.validate("") // true
hagim.validate("123.4") // true
hagim.validate("[email protected]") // true
The element itself can be an array too, e.g:
let rules = new Hagim([{is: "empty"}, [{is: "number"}, {is: "integer"}]])
usage
Rules are organized in an array, and every rule contains a validator and an operand. Operands can be an element
or an entity
or any kinds of data.
const Hagim = require('hagim');
new Hagim([{is: "number"}, {is: "integer"}]).validate(2) // true
validators
is
whether the string represent a special string or number(more details on entities section)
isNot
the opposite of is
are
whether all the members of a string belong to a certain character set(more details on elements section)
match
whether the string match a certain regular express. Under the hood the function re.test()
is used
exist
whether the string includes a certain kind of characters(more details on elements section)
haveString
the same as exist
contains
whether the string contains a certain substring
required
whether the string is not empty
gt
whether it is greater than the operand
lt
whether it is lower than the operand
goe
whether it is greater than or equal to the operand
loe
whether it is lower than or equal to the operand
equal
whether it equals the operand, under the hood ==
is used for comparing
dplacesGt
whether the digits of decimal part is greater than the operand
dplacesLt
whether the digits of decimal part is Lower than the operand
dlengthOf
whether the digits of decimal part equals the operand
lengthGt
whether the length of the string is greater than the operand
lengthLt
whether the length of the string is lower than the operand
lengthOf
whether the length of the string equsls the operand
beginWithSub
whether the string begin with a certain word
notBeginWithSub
whether the string don't begin with a certain word
startWithSet
whether the first member of the string belongs to a certain kind of characters(more details on elements section)
notStartWithSet
whether the first member of the string does not
belong to a certain kind of characters(more details on elements section)
entities
Each entity represents a certain kind of strings, like a number
or an email
. is
and isNot
can be used to judge whether the string represents a certain entity.
let hagim = new Hagim([{is: "number"}])
hagim.validate("2") // true
If there is no such a entity match you need, you can extend this lib by yourself, check plugin section for details.
number
whether the string represent a number
integer
whether the string represent an integer
decimal
whether the string represent a decimal number
positive
whether the string represent a positive number
negative
whether the string represent a negative number
whether the string represents a email
empty
whether the string is ""
, null
, undefined
or []
ip
whether the string represent an ip address
url
whether the string represent a url
elements
Each element represents a certain character set, like Latin letters or digits. are
can be used to judge whether all of the members of a string belong to a certain set.
latin
whether the character belongs to latin letter set
enLetter
currently the same to latin
digit
whether the character belongs to 0-9
logic conjunction and disjunction
By default the rules in a array will be treated in an and
-like manner, but it depends on you whether to change it. You can set it by appending an additional truthy value into the rules array. e.g:
new Hagim([{is: "number"}, {is: "empty"}, true]).validate("2.3") //true
new Hagim([{is: "number"}, {is: "empty"}, true]).validate("") //true
You can specify a disjunction manner in every array, includes nested arrays, or leave it in a conjunction manner by default.
plugin
Third-party plugins are available by means of the extension API. Currently only entities
and elements
can be extended.
For instance, if you want to define a plugin which extends Hagim to have a capability to judge whether the operand is a binary number, it should be like this:
Hagim.extend("entities", {
binary: funciton(value){
return /[01]+/.test(value)
}
})