码迷,mamicode.com
首页 > 其他好文 > 详细

[xsd学习]复合元素

时间:2015-05-06 01:13:02      阅读:184      评论:0      收藏:0      [点我收藏+]

标签:

对于xsd,复合元素的定义有两种方式:

一、在元素内部直接声明,此种方法只能此元素使用

<xs:element name="employee">
  <xs:complexType>
    <xs:sequence>
      <xs:element name="firstname" type="xs:string"/>
      <xs:element name="lastname" type="xs:string"/>
    </xs:sequence>
  </xs:complexType>
</xs:element>

二、以单独类型进行声明,此种方法,类型可以在多个元素共享

<xs:element name="employee" type="personinfo"/>

<xs:complexType name="personinfo">
  <xs:sequence>
    <xs:element name="firstname" type="xs:string"/>
    <xs:element name="lastname" type="xs:string"/>
  </xs:sequence>
</xs:complexType>

xsd有四种类型的复合元素,下边我们学习每种元素的定义

一、空元素

<product pid="1345"/>

上述元素,没有包含子内容,仅包含一个属性,声明方式为:

<xs:element name="product">
  <xs:complexType>
    <xs:attribute name="pid" type="xs:positiveInteger"/>
  </xs:complexType>
</xs:element>

二、包含其他元素的元素

<employee>
  <firstname>John</firstname>
  <lastname>Smith</lastname>
</employee>

上边内容仅包含两个子元素,没有属性,声明方式为:

<xs:element name="person">
  <xs:complexType>
    <xs:sequence>
      <xs:element name="firstname" type="xs:string"/>
      <xs:element name="lastname" type="xs:string"/>
    </xs:sequence>
  </xs:complexType>
</xs:element>

三、仅包含文本的元素(这个其实不是特别明白)

<food type="dessert">Ice cream</food>

此元素为单独空白文本,应该为简单类型,需要使用simpleContent进行声明,但不是特别明白为何作为复合类型使用,不知道是不是因为有属性的原因,声明方式为:

<xs:element name="food">
  <xs:complexType>
    <xs:simpleContent>
      <xs:extension base="xs:string">
        <xs:attribute name="dessert" type="xs:string" />
      </xs:extension>
    </xs:simpleContent>
  </xs:complexType>
</xs:element>

四、包含元素和文本的元素

<description>
It happened on <date lang="norwegian">03.03.99</date> ....
</description>

为了使字符数据可以出现在 "description" 的子元素之间,mixed 属性必须被设置为 "true",<xs:sequence>中的属性需要依次出现

<xs:element name="description">
  <xs:complexType mixed="true">
    <xs:sequence>
      <xs:element name="norwegian" type="xs:string"/>
    </xs:sequence>
  </xs:complexType>
</xs:element>

注意:以上每种元素都可以包含属性

 

[xsd学习]复合元素

标签:

原文地址:http://www.cnblogs.com/jyyzzjl/p/4480661.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!