zoukankan      html  css  js  c++  java
  • [xsd学习]复合元素

    对于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>

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

     
  • 相关阅读:
    火狐浏览器kaptcha验证码点击无法刷新问题解决方法
    算法学习笔记——洗碗时遇到的汉诺塔问题
    JSP学习笔记
    springmvc中Tomcat跨服务器上传中文名文件报错解决方案
    MAVEN项目报错解决方法集锦(1)
    原生js模板语法之underscore.js
    HTML针式打印机打印模板
    elementui form表单验证
    vue+swiper背景图随swiper改变
    uni.navigateTo和uni.switchTab的区别
  • 原文地址:https://www.cnblogs.com/jyyzzjl/p/4480661.html
Copyright © 2011-2022 走看看