XSD虽无内置“键值对”类型,但可通过属性+文本(如30)、双子元素(如languagezh-CN)或xs:key/xs:keyref约束实现键值语义,选择取决于校验、扩展与引用需求。
XSD 本身没有直接叫“键值对”的内置类型,但可以通过组合元素、属性和复杂类型,清晰表达键值对的语义结构。关键不在于命名,而在于如何让 XML 实例能被准确验证并体现“一个键对应一个值”的逻辑关系。
这是最常见也最简洁的方式:把“键”定义为元素的属性,把“值”放在元素文本内容中。
30
),且 key 属性天然具备唯一标识性适合需要对“键”本身也做复杂约束(比如多语言键名、带注释的键)的场景。
language zh-CN
xs:key 配合 XPath 实现,见下一条)当你的键值对集合要参与关联(比如多个地方引用同一个 key),就需要用 XSD 的完整性约束机制。
下定义若干 127.0.0.1 ,又在另一处用 引用它
能确保所有 @target 值必须在某个 entry/@key 中真实存在如果键是有限枚举值(比如只允许 "theme"、"lang"、"mode"),可以配合 xs:restriction 和 xs:enumeration 加强校验。
基本上就这些。不需要强行套用“键值对”字眼,重点是根据数据用途选择合适结构:轻量配置用属性+文本,需扩展性用双子元素,要跨元素引用就加 key/keyref。不复杂但容易忽略的是——键的语义是否真需要被校验或关联,这决定了要不要上约束机制。