Joi 覆盖键嵌套模式
Joi override keys nested schemas
所以我有一个类似
的架构
const buttonSchema = Joi.object().keys({
object: Joi.string().valid('button').required(),
id: Joi.string().required(),
text: textSchema.required(),
icon: Joi.string().uri({
scheme: 'https'
}),
action: actionSchema,
styles: stylesSchema.required()
});
const stylesSchema = Joi.object().keys({
width: Joi.string().pattern(/^[1-9][0-9]?%$|^100%$/).required(), // 1 - 100 %
height: Joi.number().positive(),
position: Joi.string().valid('left', 'center', 'right'),
align: Joi.string().valid('left', 'center', 'right'),
default: defaultStylesSchema.required(),
disabled: defaultStylesSchema.required(),
pressed: defaultStylesSchema.required()
});
在另一个文件中,我试图覆盖 buttonSchema.styles.align 属性 .. 基本上添加一个 required()..
我尝试了很多变化..
这是最突出的
const reactionsButtonSchema = buttonSchema.keys({
styles: buttonSchema.styles.keys({
align: Joi.string().valid('left', 'center', 'right').required(),
})
});
但它不起作用..任何人都知道如何实现这一点?
在 JOI 的支持响应后,可以使用
完成此操作
const reactionsButtonSchema = buttonSchema.concat(Joi.object({ styles: { align: Joi.required() }}));
如果其他人遇到过这个问题,您就有答案了。
所以我有一个类似
的架构const buttonSchema = Joi.object().keys({
object: Joi.string().valid('button').required(),
id: Joi.string().required(),
text: textSchema.required(),
icon: Joi.string().uri({
scheme: 'https'
}),
action: actionSchema,
styles: stylesSchema.required()
});
const stylesSchema = Joi.object().keys({
width: Joi.string().pattern(/^[1-9][0-9]?%$|^100%$/).required(), // 1 - 100 %
height: Joi.number().positive(),
position: Joi.string().valid('left', 'center', 'right'),
align: Joi.string().valid('left', 'center', 'right'),
default: defaultStylesSchema.required(),
disabled: defaultStylesSchema.required(),
pressed: defaultStylesSchema.required()
});
在另一个文件中,我试图覆盖 buttonSchema.styles.align 属性 .. 基本上添加一个 required()..
我尝试了很多变化.. 这是最突出的
const reactionsButtonSchema = buttonSchema.keys({
styles: buttonSchema.styles.keys({
align: Joi.string().valid('left', 'center', 'right').required(),
})
});
但它不起作用..任何人都知道如何实现这一点?
在 JOI 的支持响应后,可以使用
完成此操作const reactionsButtonSchema = buttonSchema.concat(Joi.object({ styles: { align: Joi.required() }}));
如果其他人遇到过这个问题,您就有答案了。