Document Type Definition (DTD) Tutorial

This tutorial covers the basics of DTDs. Before reading this tutorial you should already be familiar with XML. You may want to read my XML tutorial. Click on the above XML link to do so.

What is a DTD?

DTD stands for Document Type Definition.

XML lets applications share data easily. However, XML lets you make up your own set of tags. A DTD defines the legal elements and their structure in an XML document.

Independent developers can agree to use a common DTD for exchanging XML data. Your application can use this agreed upon DTD to verify the data it receives. The DTD can also be used to verify your own data.

DTD standards are defined by the World Wide Web Consortium (W3C). The W3C site provides a comprehensive reference of DTDs.

However, this tutorial focuses on Microsoft's implementation of the XML and DTDs. All examples contained herein require Internet Explorer 5.0 or later.

Using a DTD in an XML Document

DTDs can be declared inline in your XML code or they can reference an external file.

This is an example of an internal DTD. You can open it in Explorer then select View | Source to view the complete XML document with the DTD included.


<?xml version="1.0"?>
<!DOCTYPE message [
   <!ELEMENT message (to,from,subject,text)>
   <!ELEMENT to (#PCDATA)>
   <!ELEMENT from (#PCDATA)>
   <!ELEMENT subject (#PCDATA)>
   <!ELEMENT text (#PCDATA)>
  <text>Don't forget to buy milk on the way home.</text>

Line 2 defines the <message> element as having the four child elements: <to>, <from>, <subject> and <text>.


<!ELEMENT message (to,from,subject,text)>

This line defines the <to> element to be of type PCDATA.



Here is the same document with an external DTD reference:


<?xml version="1.0"?>
<!DOCTYPE message SYSTEM "message.dtd">
  <text>Don't forget to buy milk on the way home.</text>

And here is the referenced DTD file. You can open it in Explorer and select View | Source as above.


<?xml version="1.0"?>
<!ELEMENT message (to,from,subject,text)>
<!ELEMENT subject (#PCDATA)>


XML Components

Before talking further about DTDs, we should review some of the basic XML components.

  • XML elements
    An XML element is made up of a start and end tag with data in between. The tags describe the data. The data is called the value of the element. Elements can have a value, child elements or they can be empty (have no value).

    For example, this XML element is a <director> element with the value "Bill Smith".

    <director>Bill Smith</director>

  • Attributes
    An element can optionally contain one or more attributes in its start tag. An attribute is a name-value pair separated by an equal sign (=). Attribute values must always be quoted.

    <CITY ZIP="01085">Westfield</CITY>

    ZIP="01085" is an attribute of the <CITY> element.

  • Parsed character data - PCDATA
    Like we said, elements have values. If a value has tags representing child elements, these tags need to be expanded or parsed and handled as separate elements.

  • Character data - CDATA
    The value of an element is treated as a single item and is not expanded.

  • Entities
    Certain characters, like "<", have special meaning in XML. If you want to use these special characters in your data you need a way to tell the XML parser not to interpret them as having their normally meaning.

    Entities are sets of characters that can be used to represent these special characters or other text.


    Special Character











    To use "<" in your data, you would use the entity "&lt;" instead.

DTD Elements

In DTD, elements are declared using an element declaration with the following syntax:


<!ELEMENT element-name (element-content)>

  • Empty elements
    Empty elements use the empty keyword. Move the mouse over the text for additional information.

    <!ELEMENT img (EMPTY)>

  • Elements with data
    If an element has data, you must specify the type of its data.

    <!ELEMENT element-name (#CDATA)>
    <!ELEMENT element-name (#PCDATA)>
    <!ELEMENT element-name (ANY)>

    <!ELEMENT message (#PCDATA)>

    ANY can contain any type of data.
    #CDATA is character type data.
    #PCDATA is character data that must be parsed and expanded. If a #PCDATA section contains elements, those elements must also be declared.

  • Elements with children - Sequences
    If an element has child elements, the child elements must be enumerated in the same order that they appear in the document.

    Using the message example:

    <!ELEMENT element-name (child-element,child-element,...)>

    <!ELEMENT message (to,from,subject,text)>

    The child elements must also be declared. Here are their declarations:

    <!ELEMENT message (to,from,subject,text)>
    <!ELEMENT to (#CDATA)>
    <!ELEMENT from (#CDATA)>
    <!ELEMENT subject (#CDATA)>
    <!ELEMENT text (#CDATA)>

  • DOCTYPE definition
    With an internal DTD, you need a DOCTYPE definition to indicate the DTD code.

    <!DOCTYPE root-element [element declarations]>


    <?xml version="1.0"?>
    <!DOCTYPE message [
      <!ELEMENT message (to,from,subject,text)>
      <!ELEMENT to         (#CDATA)>
      <!ELEMENT from      (#CDATA)>
      <!ELEMENT subject (#CDATA)>
      <!ELEMENT text     (#CDATA)>
      <text>Don't forget to buy milk on the way home.</text>

  • Element instances
    You can specify how many times an element can occur in a document.




    must occur exactly 1 time


    0 or more times


    1 or more times


    Exactly 0 or 1 time

    For example:

    <!Element message (to+,from,subject?,text,#PCDATA)>

DTD Attribute Declaration

In DTD, attributes are declared using an ATTLIST declaration. An attribute declaration specifies the associated element, the attribute, its type, and possibly its default value. Here are the syntax variations:


<!ATTLIST element-name attribute-name attribute-type #DEFAULT  default-value>

<!ATTLIST element-name  attribute-name attribute-type #FIXED   fixed_value>

<!ATTLIST element-name attribute-name attribute-type (Val1|Val2|..) default_val>

<!ATTLIST element-name attribute-name attribute-type  #IMPLIED>  

<!ATTLIST element-name attribute-name attribute-type  #REQUIRED>

  • Attribute type
    Attributes can have these types:




    Character data


    An entity


    List of entities data


    Unique ID data


    ID of another element


    List of IDs of other elements


    XML name data


    List of XML names


    Name of a notation


    List of values


    Predefined value

  • Default values
    Attribute default values can be:

    Default Value


    #DEFAULT value

    If no value exists in the XML data, the value specified in the DTD will be used

    #FIXED value

    If another value exists in the XML data, an error will occur


    The value doesn't have to be supplied in the XML data.


    If the XML data doesn't have a value, an error will occur.

  • DTD Examples
    Here are some sample DTD statements. Move the mouse over the text for more information.

    <!ATTLIST person gender CDATA #DEFAULT "male">

    <!ATTLIST person gender CDATA #FIXED "male">

    <!ATTLIST person gender CDATA #REQUIRED>

    <!ATTLIST person gender CDATA #IMPLIED>

    <!ATTLIST person gender (male|female) "male">

    Here is an XML statement that will satisfy all of the above DTD statements.

    <person gender="male">

    This XML statement does not satisfy DTD rule 2 which requires a value of "male".

    <person gender="female">

    This XML statement fails DTD rule 5 because "unknown" is not an acceptable value.

    <person gender="unknown">

DTD Entity Declaration

Recall, entities are variables that represent other values. The value of the entity is substituted for the entity when the XML document is parsed.

Entities can be defined internally or externally to your DTD.


Internal declaration:
<!ENTITY entity-name entity-value>

<!ENTITY website "http://www.TheScarms.com">

External declaration:
<!ENTITY entity-name SYSTEM "entity-URL">

<!ENTITY website SYSTEM "http://www.TheScarms.com/entity.xml">

The above entity make this line of XML valid.


XML line:

Evaluates to:


Complete DTD Example

Click this link to view a complete DTD example.


About TheScarms
About TheScarms

Sample code
version info

If you use this code, please mention "www.TheScarms.com"

Email this page

The World's Number 1 Web Host

© Copyright 2015 TheScarms
Goto top of page