substitutionGroup 是 XSD 中实现元素可替代关系的机制,由 abstract 头部元素和 substitutionGroup 引用的成员元素构成,成员可在 XML 实例中直接替换头部元素位置,需类型兼容、同命名空间,仅适用于元素且不支持跨命名空间或属性。
substitutionGroup 是 XSD(XML Schema Definition)中用于定义元素间“可替代关系”的机制,它允许一个元素在 XML 实例文档中**直接代替另一个元素出现**,而无需修改 Schema 结构或使用 xsi:type 等扩展手段。
它由两个核心部分组成:
abstract="true",表示它本身不能直接出现在 XML 中,只作为占位符;substitutionGroup="headElementName" 显式声明自己可替代该头部元素。例如:
此时 不能直接写在 XML 里,但 或 都可以合法出现在原本要求 的位置。
可替代性不是靠运行时动态判断,而是由 Schema 解析器在验证阶段静态检查的。关键规则包括:
),那么任一成员元素都可原位代入。这种机制常用于建模具有共同语义角色、但具体类型不同的元素,比如:
作 head,、、 作成员; 抽象,被 、、 替代;
定义扩展点(abstract 元素),第三方通过声明 substitutionGroup 接入自定义元素。substitutionGroup 不是继承也不是多态,它有明确边界:
xmlns 正确声明);基本上就这些。它本质是一种轻量级的“接口式”元素抽象,让 XML 结构保有扩展性,又不牺牲验证的确定性。