Explication détaillée de la DTD
DTDExplication détaillée
Aperçu de base
Définition du type de document(Définition du type de document) est un ensemble de règles grammaticales sur les balises établies pour l'échange de données entre programmes. Il fait partie du langage de balisage standard généralisé (SGML) et du langage de balisage extensible (XML) version 1.0, et est documenté sous Une sorte de règle de syntaxe DTD vérifie que le format est conforme à cette règle. Les définitions de types de documents peuvent également être utilisées pour garantir la légalité des formats de documents en langage de balisage universel standard et en langage de balisage extensible. Vous pouvez comparer des documents avec des fichiers de définition de type de document pour vérifier si le document est conforme à la spécification et si les éléments et les balises sont utilisés correctement. . Les instances de fichiers fournissent aux applications un format d'échange de données.
PS : En bref, DTD sert à contraindre XML document, afin qu'il puisse être utilisé sous certaines spécifications. En plus de la technologie DTD, il existe également la technologie Schema, qui est également utilisé pour les documents XML contraints.
Document de référence : DTD http://www.php.cn/
Document de référence : Schéma http://www.php.cn/
DTDSchéma
PS : contraint par DTD, XML peut être personnalisé sous les contraintes de DTD, mais DTD a un inconvénient est que il ne peut pas imposer de contraintes de plage telles que des contraintes numériques sur les données.
DTDDéclaration et référence du document
InterneDTDDocument
Élément racine [Contenu de la définition]>
ExterneDTDDocument
Élément racine SYSTEM "DTD Chemin du fichier">
DTD interne et externeCombinaison de documents
Élément racine SYSTEM "DTDChemin du fichier" [
Contenu de la définition
]>
Remarque :
1, les mots-clés de définition doivent être en majuscules, par exemple : DOCTYPE, ÉLÉMENT, ATTLISTE.
2,
Lorsque le fichier référencé est local, la méthode suivante est utilisée :
Nœud racine du document SYSTÈME "DTDURL du fichier">
Par exemple : bibliothèque SYSTEM "livre .dtd”>
Lorsque le fichier référencé est un fichier public, la méthode suivante est utilisée :
Nœud racine du document PUBLIC "DTDnom" "DTD fichier URL">
Par exemple : "-//Sun Microsystems, Inc.//DTD Web Application 2.3//FR" "http://java.sun.com/dtd/web-app_2_3.dtd">
DTDElement
Syntaxe de base
Explication :
ÉLÉMENT : Mot clé (doit être en majuscule).
NOM : nom de l'élément.
CONTENU : Il existe quatre types d'éléments, tous doivent être en majuscules.
1, EMPTY - Cet élément ne peut pas contenir de sous-éléments et de texte, mais peut avoir des attributs (éléments vides)
2, ANY - Cet élément peut contenir n'importe quoi en DTD Le contenu de l'élément défini dans
3, #PCDATA - peut contenir n'importe quelle donnée de caractère, mais ne peut pas le faire. contient des éléments enfants
4, d'autres types (combinaison) , peut être un élément enfant, une combinaison d'éléments enfants et de modificateurs, un élément de base, une combinaison d'éléments enfants et de modificateurs.
Cas :
Classe (Étudiant ,Auteur)>
Étudiant (Nom,Âge,Introduction)>
< !ELEMENT Auteur (#PCDATA)>
Nom (#PCDATA)>
Âge (#PCDATA)>
Introduction ( #PCDATA)>
Modificateur
Symbole |
Objectif |
Exemple |
Exemple de description |
( ) |
est utilisé pour regrouper des éléments |
(古龙|Jin Yong|Liang Yusheng),(Wang Shuo |Yu Jie) |
Divisé en deux groupes |
| | Choisissez l'un des objets répertoriés |
(homme|femme) |
signifie qu'un homme ou une femme doit apparaître, et vous ne pouvez en choisir qu'un |
|
L'objet apparaît au moins une fois et peut apparaître plusieurs fois (1 ou plusieurs fois) |
(membres ) |
signifie que les membres doivent apparaître , et plusieurs membres peuvent apparaître |
* |
Cet objet peut apparaître de zéro à n'importe quel nombre de fois (0À plusieurs fois) |
(Hobby*) |
Le passe-temps peut apparaître de zéro à plusieurs fois |
? |
Cet objet peut apparaître, mais seulement Peut apparaître une fois (0 à 1 fois) |
(Rookie?) |
Le rookie peut apparaître ou non apparaître. S'il apparaît, au maximum Peut apparaître une fois |
, |
Les objets doivent apparaître dans l'ordre spécifié |
(pastèque,pomme,banane ) |
signifie que la pastèque, la pomme, la banane doivent apparaître, et apparaître dans cet ordre |
DTDAttributs
Syntaxe de base
Nom de l'élément
Nom de l'attribut Type Caractéristiques de l'attribut
Nom de l'attribut Type Caractéristiques de l'attribut......
>
Explication :
ATTLIST : liste d'attributs, ( doit être en majuscule).
Nom de l'élément : le nom de l'élément correspondant.
Attribut : Il peut y avoir plusieurs attributs, et le format est Nom Type Caractéristiques de l'attribut
Type :
PS : Ceux couramment utilisés sont CDATA(Type de caractère ), énumération ( le format de l'énumération est (valeur1| valeur2|valeur3...)), ID(ID ne peut pas être répété et ne peut pas commencer par un chiffre ), IDREF ( fait référence à un autre ID Valeur), IDREFS( peut référencer plusieurs ID Valeurs, séparées par des espaces )
Les caractéristiques des attributs sont :
Cas :
<!ELEMENT 班级 (学生+,作者)> <!ATTLIST 班级 班次 CDATA "1班" 编号 ID #REQUIRED > <!ELEMENT 学生 (名字,年龄,介绍)> <!ELEMENT 作者 (#PCDATA)> <!ATTLIST 学生 地址 CDATA #IMPLIED 授课方式 CDATA #FIXED "面授" 学号 ID #REQUIRED 班级编号 IDREF #REQUIRED 朋友 IDREFS #IMPLIED > <!ELEMENT 名字 (#PCDATA)> <!ELEMENT 年龄 (#PCDATA)> <!ELEMENT 介绍 (#PCDATA)>
Entité
Il existe deux types d'entités : les entités de référence et les entités paramètres sont généralement utilisées en XML, et les entités paramètres sont généralement utilisées en DTD<🎜. > utilisation.
Syntaxe de baseNom de l'entité "Contenu de l'entité" > // Entité de référence
Nom de l'entité "Contenu de l'entité" > // Entité paramètre
Explication : 1, l'entité de référence peut être référencée dans DTD 🎜 >Fichier XML, utilisez &nom de l'entité; pour utiliser le contenu de l'entité. 2
. Je ne sais pas si c'est à cause de mon ordinateur Vous ne pouvez pas utiliser d'entités de référence enDTD externe. vous l'utilisez, mettez la définition de l'entité de référence dans Elle peut être utilisée dans DTD. 3
, l'entité paramètre est utilisée dansDTD, utilisez %nom de l'entité;Utiliser 4、可以将那些重复使用的值定义成实体,这样能减少代码的冗余度。 5、在外部DTD中,引用实体最好放在DTD底部,参数实体最好放在DTD顶部。 案例: 综合案例1: XML3.dtd XML3.xml 综合案例2: XML4.dtd XML4.xml 以上就是DTD详解的内容,更多相关内容请关注PHP中文网(www.php.cn)!<!ENTITY % sex "男|女">
<!ELEMENT 班级 (学生+,作者)>
<!ELEMENT 学生 (名字,年龄,介绍)>
<!ELEMENT 作者 (#PCDATA)>
<!ATTLIST 学生
性别 (%sex;) #REQUIRED
>
<!ELEMENT 名字 (#PCDATA)>
<!ELEMENT 年龄 (#PCDATA)>
<!ELEMENT 介绍 (#PCDATA)>
<!ENTITY writer "Switch">
<!ENTITY % sex "男|女">
<!ELEMENT 班级 (学生+,作者)>
<!ATTLIST 班级
班次 CDATA "1班"
编号 ID #REQUIRED
>
<!ELEMENT 学生 (名字,年龄,介绍)>
<!ELEMENT 作者 (#PCDATA)>
<!ATTLIST 学生
地址 CDATA #IMPLIED
授课方式 CDATA #FIXED "面授"
学号 ID #REQUIRED
班级编号 IDREF #REQUIRED
朋友 IDREFS #IMPLIED
性别 (%sex;) #REQUIRED
>
<!ELEMENT 名字 (#PCDATA)>
<!ELEMENT 年龄 (#PCDATA)>
<!ELEMENT 介绍 (#PCDATA)>
<?xml version="1.0" encoding="UTF-8"?>
<!-- 引入DTD -->
<!DOCTYPE 班级 SYSTEM "XML3.dtd"
[<!ENTITY writer "Switch">]>
<班级 编号="C1" 班次="1班">
<学生 地址="湖南" 授课方式="面授" 学号="n1" 班级编号="C1" 朋友="n2" 性别="男">
<名字>张三</名字>
<年龄>20</年龄>
<介绍>不错</介绍>
</学生>
<学生 授课方式="面授" 学号="n2" 班级编号="C1" 朋友="n1 n3" 性别="女">
<名字>李四</名字>
<年龄>18</年龄>
<介绍>很好</介绍>
</学生>
<学生 授课方式="面授" 学号="n3" 班级编号="C1" 朋友="n2" 性别="男">
<名字>王五</名字>
<年龄>22</年龄>
<介绍>非常好</介绍>
</学生>
<作者>&writer;</作者>
</班级>
<!ENTITY AUTHOR "John Doe">
<!ENTITY COMPANY "JD Power Tools, Inc.">
<!ENTITY EMAIL "jd@jd-tools.com">
<!ELEMENT CATALOG (PRODUCT+)>
<!ELEMENT PRODUCT
(SPECIFICATIONS+,OPTIONS?,PRICE+,NOTES?)>
<!ATTLIST PRODUCT
NAME CDATA #IMPLIED
CATEGORY (HandTool|Table|Shop-Professional) "HandTool"
PARTNUM CDATA #IMPLIED
PLANT (Pittsburgh|Milwaukee|Chicago) "Chicago"
INVENTORY (InStock|Backordered|Discontinued) "InStock">
<!ELEMENT SPECIFICATIONS (#PCDATA)>
<!ATTLIST SPECIFICATIONS
WEIGHT CDATA #IMPLIED
POWER CDATA #IMPLIED>
<!ELEMENT OPTIONS (#PCDATA)>
<!ATTLIST OPTIONS
FINISH (Metal|Polished|Matte) "Matte"
ADAPTER (Included|Optional|NotApplicable) "Included"
CASE (HardShell|Soft|NotApplicable) "HardShell">
<!ELEMENT PRICE (#PCDATA)>
<!ATTLIST PRICE
MSRP CDATA #IMPLIED
WHOLESALE CDATA #IMPLIED
STREET CDATA #IMPLIED
SHIPPING CDATA #IMPLIED>
<!ELEMENT NOTES (#PCDATA)>
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE CATALOG SYSTEM "XML4.dtd">
<CATALOG>
<PRODUCT NAME="C'estbon" CATEGORY="Shop-Professional" INVENTORY="Backordered" PARTNUM="10" PLANT="Chicago">
<SPECIFICATIONS POWER="0" WEIGHT="555ml">SPECIFICATIONS</SPECIFICATIONS>
<OPTIONS>OPTIONS</OPTIONS>
<PRICE>2</PRICE>
<NOTES>NOTES</NOTES>
</PRODUCT>
</CATALOG>

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Cet article détaille la modification des valeurs d'attribut XML, mettant en évidence les limitations résultant de la bonne forme, de la validation du schéma / DTD et du codage des caractères. Il met l'accent

Cet article explique comment utiliser les flux RSS pour une agrégation de nouvelles efficace et une conservation du contenu. Il détaille l'abonnement à des flux, à l'aide de lecteurs RSS (comme Feedly et INOREADER), en organisant des flux et en tirant parti des fonctionnalités pour le contenu ciblé. Le bene

La modification du contenu XML a un impact significatif sur les performances de l'application, en particulier avec des fichiers volumineux. L'analyse, la manipulation DOM, la sérialisation et les opérations d'E / S y contribuent. Les stratégies d'optimisation incluent l'utilisation des analyseurs de streaming, la minimisation D

Cet article s'attaque à une modification efficace des fichiers XML. Il met en évidence l'inefficacité du traitement en mémoire, prônant les approches de streaming comme l'analyse de sax et de stax. Les stratégies d'optimisation incluent l'analyse incrémentielle, les données optimisées

Cet article détaille les méthodes de conversion des données XML. Il relève des défis dans la transformation des formats de données dans les documents XML, mettant en évidence des techniques efficaces telles que le traitement XSLT et Stream. L'article couvre également les pièges potentiels, comme SCH

Cet article détaille la mise en œuvre de la syndication du contenu à l'aide de flux RSS. Il couvre la création de flux RSS, l'identification des sites Web cibles, la soumission des flux et la surveillance de l'efficacité. Des défis comme le contrôle limité et le soutien des médias riches sont également des disques

Cet article explore l'intégration des technologies XML et sémantiques. Le problème de base est de mappage des données structurées de XML aux triples RDF pour l'interopérabilité sémantique. Les meilleures pratiques impliquent une définition de l'ontologie, des approches de cartographie stratégique, un ATT prudent

Cet article détaille les flux RSS contre un accès non autorisé. Il examine diverses méthodes, notamment l'authentification HTTP, les clés d'API avec limitation du taux, HTTPS et obscurcir le contenu (découragé). Les meilleures pratiques impliquent une restriction IP, revers
