我有一个用例,我需要验证一组由 | 分隔的值 。
我关注了https://github.com/hapijs/joi/issues/570但它引发了许多错误。我有什么办法可以做到这一点吗?
示例 - AA|BB|CC|DD
现在,我需要验证所有值(AA、BB、CC、DD)都是字符串。
我相信我不能使用正则表达式,因为它只会验证第一个值。
另外,我的代码中还有许多其他验证,因此我不希望循环验证过程。
如果我不清楚,请告诉我。谢谢!
长话短说:
const Joi = require('joi').extend(joi => ({
base: joi.array(),
coerce: (value, helpers) => ({
value: value.split ? value.split('|') : value,
}),
type: 'versionArray',
}))
Run Code Online (Sandbox Code Playgroud)
自该评论撰写以来,函数.extend 签名已更改;该name属性已被删除,并且应该返回一个具有该属性的CoerceFunction对象。value
> Joi.versionArray().validate('AA|BB|CC|DD')
{ value: [ 'AA', 'BB', 'CC', 'DD' ] }
> Joi.versionArray().validate('AA|BB,CC|DD')
{ value: [ 'AA', 'BB,CC', 'DD' ] }
Run Code Online (Sandbox Code Playgroud)
从这里开始,您可以使用该.items(...)函数来验证返回数组中的每个字符串:
> const regex = new RegExp('^[a-zA-Z]+$') // every character must be a-z or A-Z
undefined
> Joi.versionArray().items(Joi.string().regex(regex)).validate('AA|BB|CC|DD')
{ value: [ 'AA', 'BB', 'CC', 'DD' ] }
> Joi.versionArray().items(Joi.string().regex(regex)).validate('AA|BB|CC|00')
{ value: [ 'AA', 'BB', 'CC', '00' ],
error:
{ ValidationError: "[3]" with value "00" fails to match the required pattern: /^[a-zA-Z]+$/ _original: 'AA|BB|CC|00', details: [ [Object] ] } }
> Joi.versionArray().items(Joi.string().regex(regex)).validate('AA|BB,CC|DD')
{ value: [ 'AA', 'BB,CC', 'DD' ],
error:
{ ValidationError: "[1]" with value "BB,CC" fails to match the required pattern: /^[a-zA-Z]+$/ _original: 'AA|BB,CC|DD', details: [ [Object] ] } }
Run Code Online (Sandbox Code Playgroud)