Una Herramienta Sumor Cloud.
Más Documentación
Este es un validador ligero para Node.JS. Puede validar la cadena de entrada o número basándose en las reglas que se han definido.
npm i @sumor/validator --save
Requiere Node.JS versión 16.x o superior
Como este paquete está escrito en módulo ES,
por favor cambia el siguiente código en tu archivo package.json
:
{
"type": "module"
}
import { validar } from '@sumor/validator'
const informaciónParámetro = {
tipo: 'cadena',
requerido: true,
longitud: 10,
regla: [
// solo permitir a-z, A-Z, 0-9
{
código: 'SOLO_CARÁCTER_DIGITO',
expresión: '^[a-zA-Z0-9]*$',
mensaje: 'solo permitir a-z, A-Z, 0-9'
},
// necesita incluir demo
{
código: 'INCLUIR_DEMO',
expresión: 'demo',
mensaje: 'necesita incluir demo'
},
// usar función para verificar
{
código: 'LONGITUD_MAYOR_A_5',
expresión: valor => {
return valor.length > 5
},
mensaje: 'la longitud debe ser mayor a 5'
}
],
i18n: {
zh: {
SOLO_CARÁCTER_DIGITO: 'sólo permitir entrada letra y dígito',
INCLUIR_DEMO: 'necesita incluir demo',
LONGITUD_MAYOR_A_5: 'longitud debería ser mayor a 5'
},
'zh-TW': {
SOLO_CARÁCTER_DIGITO: 'sólo permitir entrada letra y dígito',
INCLUIR_DEMO: 'necesita incluir demo',
LONGITUD_MAYOR_A_5: 'longitud debería ser mayor a 5'
}
}
}
const mensajes1 = validar(informaciónParámetro, 'demo123456')
console.log(mensajes1) // []
const mensajes2 = validar(informaciónParámetro, 'de1234567')
console.log(mensajes2) // [ 'solo permitir a-z, A-Z, 0-9' ]
const mensajes3 = validar(informaciónParámetro, 'demo!')
console.log(mensajes3) // [ 'solo permitir a-z, A-Z, 0-9', 'necesita incluir demo' ]
const mensajes4 = validar(informaciónParámetro, 'de!mo')
console.log(mensajes4) // [ 'solo permitir a-z, A-Z, 0-9', 'necesita incluir demo' ]
const mensajes5 = validar(informaciónParámetro, 'de')
console.log(mensajes5) // [ 'solo permitir a-z, A-Z, 0-9', 'necesita incluir demo', 'la longitud debe ser mayor a 5' ]
// traducir a zh
const mensajes6 = validar(informaciónParámetro, 'de', 'zh')
console.log(mensajes6) // [ 'sólo permitir entrada letra y dígito', 'necesita incluir demo', 'longitud debería ser mayor a 5' ]
// traducir a zh-TW
const mensajes7 = validar(informaciónParámetro, 'de', 'zh-TW')
console.log(mensajes7) // [ 'sólo permitir entrada letra y dígito', 'necesita incluir demo', 'longitud debería ser mayor a 5' ]
import { validar } from '@sumor/validator'
const informaciónParámetro = {
tipo: 'número',
requerido: true,
regla: [
// necesidad de ser mayor que 5
{
código: 'MAYOR_QUE_5',
expresión: valor => {
return valor > 5
},
mensaje: 'el valor debe ser mayor que 5'
}
],
i18n: {
zh: {
MAYOR_QUE_5: 'el valor debe ser mayor que 5'
},
'zh-TW': {
MAYOR_QUE_5: 'el valor debe ser mayor que 5'
}
}
}
const mensajes1 = validar(informaciónParámetro, 6)
console.log(mensajes1) // []
const mensajes2 = validar(informaciónParámetro, 5)
console.log(mensajes2) // [ 'el valor debe ser mayor que 5' ]
const mensajes3 = validar(informaciónParámetro, 4)
console.log(mensajes3) // [ 'el valor debe ser mayor que 5' ]
// traducir a zh
const mensajes4 = validar(informaciónParámetro, 4, 'zh')
console.log(mensajes4) // [ 'el valor debe ser mayor que 5' ]
// traducir a zh-TW
const mensajes5 = validar(informaciónParámetro, 4, 'zh-TW')
console.log(mensajes5) // [ 'el valor debe ser mayor que 5' ]
eliminará los espacios inútiles de prefijo y sufijo
import { formato } from '@sumor/validator'
const informaciónParámetro = {
tipo: 'cadena',
recortar: true // por defecto es true para el tipo cadena
}
const valor = formato(informaciónParámetro, ' demo ')
console.log(valor) // imprimirá "demo", se eliminarán los espacios inútiles
convertirá la cadena a minúsculas
import { formato } from '@sumor/validator'
const informaciónParámetro = {
tipo: 'cadena',
minúsculas: true
}
const valor = formato(informaciónParámetro, 'Demo')
console.log(valor) // imprimirá "demo", todos los caracteres se convertirán a minúsculas
convertirá la cadena a mayúsculas
import { formato } from '@sumor/validator'
const informaciónParámetro = {
tipo: 'cadena',
mayúsculas: true
}
const valor = formato(informaciónParámetro, 'Demo')
console.log(valor) // imprimirá "DEMO", todos los caracteres se convertirán a mayúsculas
import { formato } from '@sumor/validator'
const informaciónParámetro = {
tipo: 'número',
decimal: 2
}
const valor1 = formato(informaciónParámetro, 1.234)
console.log(valor1) // imprimirá 1.23, solo mantiene 2 decimales
const valor2 = formato(informaciónParámetro, '1.234')
console.log(valor2) // convertirá a número 1.23, solo mantendrá 2 decimales
Si pasas error:true, la respuesta será un objeto ErrorSumor. Puedes cambiar el idioma y exportar soporte JSON mediante @sumor/error
import { validar } from '@sumor/validator'
const informaciónParámetro = {
tipo: 'cadena',
requerido: true,
longitud: 10,
regla: [
{
código: 'LONGITUD_MAYOR_A_5',
expresión: valor => {
return valor.length > 5
},
mensaje: 'la longitud debe ser mayor a 5'
}
]
}
const mensajes = validar(informaciónParámetro, 'demo123456', 'es', true)
console.log(mensajes)
/*
SumorError
{
código: 'LONGITUD_MAYOR_A_5',
mensaje: 'la longitud debe ser mayor a 5'
}
*/