@sumor/validator

validateur

Un outil Sumor Cloud.
Plus de documentation

Il s'agit d'un validateur léger pour Node.JS. Il peut valider la chaîne d'entrée ou le nombre en fonction des règles que vous avez définies.

Installation

npm i @sumor/validator --save

Prérequis

Version Node.JS

Nécessite Node.JS version 16.x ou supérieure

Nécessite le module ES de Node.JS

Comme ce package est écrit en module ES, veuillez modifier le code suivant dans votre fichier package.json :

{
  "type": "module"
}

Utilisation

Utilisation de la validation de chaîne

import { validate } from '@sumor/validator'

const infosParamètre = {
  type: 'string',
  required: true,
  length: 10,
  rule: [
    // autorise uniquement a-z, A-Z, 0-9
    {
      id: 'ONLY_CHAR_DIGIT',
      expression: '^[a-zA-Z0-9]*$',
      message: 'autorise uniquement a-z, A-Z, 0-9'
    },
    // doit inclure demo
    {
      id: 'INCLUDE_DEMO',
      expression: 'demo',
      message: 'doit inclure demo'
    },
    // utilise une fonction pour vérifier
    {
      id: 'LENGTH_GREATER_THAN_5',
      expression: value => {
        return value.length > 5
      },
      message: 'la longueur devrait être supérieure à 5'
    }
  ],
  i18n: {
    zh: {
      ONLY_CHAR_DIGIT: '只允许输入字母和数字',
      INCLUDE_DEMO: '需要包含demo',
      LENGTH_GREATER_THAN_5: '长度应大于5'
    },
    'zh-TW': {
      ONLY_CHAR_DIGIT: '只允許輸入字母和數字',
      INCLUDE_DEMO: '需要包含demo',
      LENGTH_GREATER_THAN_5: '長度應大於5'
    }
  }
}

const messages1 = validate(infosParamètre, 'demo123456')
console.log(messages1) // []

const messages2 = validate(infosParamètre, 'de1234567')
console.log(messages2) // [ 'autorise uniquement a-z, A-Z, 0-9' ]

const messages3 = validate(infosParamètre, 'demo!')
console.log(messages3) // [ 'autorise uniquement a-z, A-Z, 0-9', 'doit inclure demo' ]

const messages4 = validate(infosParamètre, 'de!mo')
console.log(messages4) // [ 'autorise uniquement a-z, A-Z, 0-9', 'doit inclure demo' ]

const messages5 = validate(infosParamètre, 'de')
console.log(messages5) // [ 'autorise uniquement a-z, A-Z, 0-9', 'doit inclure demo', 'la longueur devrait être supérieure à 5' ]

// traduction en zh
const messages6 = validate(infosParamètre, 'de', 'zh')
console.log(messages6) // [ '只允许输入字母和数字', '需要包含demo', '长度应大于5' ]

// traduction en zh-TW
const messages7 = validate(infosParamètre, 'de', 'zh-TW')
console.log(messages7) // [ '只允許輸入字母和數字', '需要包含demo', '長度應大於5' ]

Utilisation de la validation de nombre

import { validate } from '@sumor/validator'

const infosParamètre = {
  type: 'number',
  required: true,
  rule: [
    // doit être supérieur à 5
    {
      id: 'GREATER_THAN_5',
      expression: value => {
        return value > 5
      },
      message: 'la valeur doit être supérieure à 5'
    }
  ],
  i18n: {
    zh: {
      GREATER_THAN_5: '值应大于5'
    },
    'zh-TW': {
      GREATER_THAN_5: '值應大於5'
    }
  }
}

const messages1 = validate(infosParamètre, 6)
console.log(messages1) // []

const messages2 = validate(infosParamètre, 5)
console.log(messages2) // [ 'la valeur doit être supérieure à 5' ]

const messages3 = validate(infosParamètre, 4)
console.log(messages3) // [ 'la valeur doit être supérieure à 5' ]

// traduction en zh
const messages4 = validate(infosParamètre, 4, 'zh')
console.log(messages4) // [ '值应大于5' ]

// traduction en zh-TW
const messages5 = validate(infosParamètre, 4, 'zh-TW')
console.log(messages5) // [ '值應大於5' ]

Utilisation du format de chaîne

import { format } from '@sumor/validator'

const infosParamètre = {
  type: 'string'
}

const valeur1 = format(infosParamètre, ' demo ')
console.log(valeur1) // affichera "demo", les espaces inutiles seront supprimés

Utilisation du format de nombre

import { format } from '@sumor/validator'

const infosParamètre = {
  type: 'number',
  decimal: 2
}

const valeur1 = format(infosParamètre, 1.234)
console.log(valeur1) // affichera 1.23, seuls 2 décimales sont conservées

const valeur2 = format(infosParamètre, '1.234')
console.log(valeur2) // sera converti en nombre 1.23, seuls 2 décimales sont conservées