添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
相关文章推荐
有腹肌的海豚  ·  HTTP Connector ...·  2 月前    · 
灰常酷的杯子  ·  uTools插件 - ChatGPT.好友·  2 月前    · 
干练的创口贴  ·  openpyxl - A Python ...·  2 月前    · 
微醺的墨镜  ·  粤港澳大湾区车展·  4 月前    · 

Requirement:
AllowedRetention element is REQUIRED element. But this element position is different in sample JSON1 and JSON2. In absence of this element validation should fail.

JSON validation should only pass for Sample JSON1 and Sample JSON2.
But it should fail for sample JSON3.

If JSON contains “Product->Retention” then REQUIRED element is AllowedRetention which is located at “Product-> Retention → AllowedRetention” in sample JSON1.

If “Retention” element is missing as per JSON2, then REQUIRED element is AllowedRetention which sitting at Product-> AllowedRetention”.

If Retention and AllowedRetention is missing as per JSON3, then schema validation should fail.

I am using https://www.jsonschemavalidator.net/ url to validate JSON against above schema.

I am not sure Schema validation don’t go to else part, not sure IF-ELSE is the right way to handle this kind of validation.
Any inputs would be much appreciated!

Thanks

Hi @Atul ,

  • In your JSON Schema you seem to accidentially nest the Product properties in the else path
  • To also “execute” the else branch when the Retention does not exist, you need to add a required: ["Retention"] to the if condition.
  • This should do what you need:

    "type": "object", "properties": { "Product": { "type": "object", "if": { "properties": { "Retention": { "type": "object" "required": [ "Retention" "then": { "properties": { "Retention": { "required": [ "AllowedRetention" "else": { "required": [ "AllowedRetention"

    Note that these kind of validations are usually much easier to express and understand when modeled as a oneOf of the allowed variants instead of using if/else .

    Technically this was only partially related to JSON Forms itself. So I would recommend checking the JSON Schema communities the next time :wink:

    Assuming, if primaryKey == “Specify” it must check EntityId and EntityName, and not customKeys. Otherwise, if primaryKey == “Auto” it must check customKeys and entityName, and not entityId.

    Actually, if I switch to “Auto”, type and clear “Entity ID”, then switch to “Specify” and try to apply the form it claims “Entity ID” must not have fewer than 1 characters.

    What’s wrong?

    Thank you!

    Edward.

    tujger:

    Actually, if I switch to “Auto”, type and clear “Entity ID”, then switch to “Specify” and try to apply the form it claims “Entity ID” must not have fewer than 1 characters.

    You are probably using an older version of JSON Forms. Up until the recent past we stored an empty string when a user emptied a text input. Only the React Material renderers additionally offered a clear button which, when used, stored undefined instead.

    In your case likely an empty string was stored. I would therefore recommend upgrading to JSON Forms 3.0.0 or using a custom renderer to store undefined instead.

    Hello Stefan,

    Thank you for your answer. Version 3.0.0 is in use. It seems it does not switch the part of schema in full until handleChange is fired. After switching primaryKey, applying the form leads to the error. But if I additionally change some of fields and apply, it’s succeeded.

    Edward.