第三十五章 XML 模式的高级选项 - 创建子类型的选择列表

文章目录

  • [第三十五章 XML 模式的高级选项 - 创建子类型的选择列表](#第三十五章 XML 模式的高级选项 - 创建子类型的选择列表)
  • 创建子类型的选择列表
    • [`XMLINCLUDEINGROUP=0` 的选择列表示例](#XMLINCLUDEINGROUP=0 的选择列表示例)

第三十五章 XML 模式的高级选项 - 创建子类型的选择列表

创建子类型的选择列表

根据 XML Schema 规范,复杂类型可以由类型(特别是相关类型)的选择列表组成。假设我们希望架构允许使用 <Person>, <Patient>, or <Employee> 元素,而不是 <Person> 元素。要定义这样的架构,我们会将 Person 属性的 XMLTYPECONSTRAINT 属性参数设置为等于"CHOICE",如下所示:

java 复制代码
Class UsingSubclasses.Example2 Extends (%Persistent, %XML.Adaptor)
{
Property Person As UsingSubclasses.Person(XMLTYPECONSTRAINT = "CHOICE");
}

默认情况下,选择列表由 Person 类的所有子类组成。示例 2 的架构如下:

xml 复制代码
<s:complexType name="Example2">
    <s:sequence>
        <s:choice minOccurs="0">
            <s:element name="Employee" type="Employee" />
            <s:element name="Patient" type="Patient" />
            <s:element name="Person" type="Person" />
        </s:choice>
    </s:sequence>
</s:complexType>
<s:complexType name="Employee">
    <s:complexContent>
        <s:extension base="Person">
            <s:sequence>
                <s:element name="EmployeeID" type="s:string" />
            </s:sequence>
        </s:extension>
    </s:complexContent>
</s:complexType>
<s:complexType name="Person">
    <s:sequence>
        <s:element name="Name" type="s:string" />
        <s:element name="DOB" type="s:date" />
    </s:sequence>
</s:complexType>
<s:complexType name="Patient">
    <s:complexContent>
        <s:extension base="Person">
            <s:sequence>
                <s:element name="PatientID" type="s:string" />
            </s:sequence>
        </s:extension>
    </s:complexContent>
</s:complexType>

与前面的示例相反,Example2 的类型是一个由 PersonPatientEmployee 组成的选择列表。后三种类型的定义方式与前面的示例相同。

XMLINCLUDEINGROUP=0 的选择列表示例

假设我们添加 Person 类的另一个子类,并通过将 XMLINCLUDEINGROUP 设置为 0 来限制它:

java 复制代码
Class UsingSubclasses.Other Extends UsingSubclasses.Person
{
Parameter XMLINCLUDEINGROUP = 0;
}

在这种情况下,此类不包含在选择列表中,也不包含在架构中。

相关推荐
漂流瓶jz4 小时前
BEM、OOCSS、SMACSS、ITCSS、AMCSS、SUITCSS:CSS命名规范简介
前端·css·代码规范
陈随易8 小时前
真的,你可以不用TypeScript
前端·后端·程序员
郑州光合科技余经理9 小时前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
feifeigo1239 小时前
matlab画图工具
开发语言·matlab
唐璜Taro9 小时前
Vue3 + TypeScript 后台管理系统完整方案
前端·javascript·typescript
dustcell.10 小时前
haproxy七层代理
java·开发语言·前端
norlan_jame10 小时前
C-PHY与D-PHY差异
c语言·开发语言
掘金酱10 小时前
「寻找年味」 沸点活动|获奖名单公示🎊
前端·人工智能·后端
患得患失94910 小时前
【前端】前端动画优化的核心
前端
Xin_z_10 小时前
Vue3 + Sticky 锚点跳转被遮挡问题解决方案
前端·javascript·vue.js