[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

PHP XML DOM

L'analyseur DOM intégré permet de traiter des documents XML en PHP.


Qu'est-ce que le DOM ?

W3C DOM fournit un ensemble standard d'objets pour les documents HTML et XML, ainsi qu'une interface standard pour accéder et manipuler ces documents.

Le DOM du W3C est divisé en différentes parties (Core, XML et HTML) et différents niveaux (DOM niveau 1/2/3) :

* Core DOM - définit un ensemble standard d'objets pour tout document structuré

* XML DOM - pour les documents XML définir un ensemble standard d'objets

* HTML DOM - Définir un ensemble standard d'objets pour les documents HTML


En savoir plus Pour en savoir plus XML DOM, veuillez visiter notre tutoriel XML DOM.


Analyse XML

Pour lire et mettre à jour - créer et traiter - un document XML, vous avez besoin d'un analyseur XML.

Il existe deux types de base d'analyseurs XML :

· Analyseur arborescent : cet analyseur convertit le document XML en une structure arborescente. Il analyse l'intégralité du document et donne accès aux éléments de l'arborescence, tels que le modèle objet de document (DOM).

· Analyseur temporel : traitez les documents XML comme une série d'événements. Lorsqu'un événement spécifique se produit, l'analyseur appelle une fonction pour le gérer.

L'analyseur DOM est un analyseur arborescent.

Veuillez consulter le fragment de document XML suivant :

<?xml version="1.0" encoding="ISO-8859-1" ?>
<from>Jani</from>

XML DOM Traitez le XML ci-dessus comme un A arborescence :

· Niveau 1 : Document XML

· Niveau 2 : Élément racine : <from>

· Niveau 3 : Élément texte : "Jani"


Installation

La fonction d'analyseur XML DOM fait partie intégrante du noyau PHP. Aucune installation n'est requise pour utiliser ces fonctions.


Fichier XML

Le fichier xml_dom.xml suivant sera utilisé dans notre exemple :

<?xml version="1.0" encoding="ISO-8859-1"?>
 <note>
     <to>Tove</to>
     <from>Jani</from>
     <heading>Reminder</heading>
     <body>Don't forget me this weekend!</body>
 </note>

Chargement et sortie XML

Nous devons initialiser l'analyseur XML, charger le XML et le sortir :

Instance

<?php
 $xmlDoc = new DOMDocument();
 $xmlDoc->load("xml_dom.xml");
 
 print $xmlDoc->saveXML();
 ?>

Le code ci-dessus affichera :

ToveJaniReminderNe m'oubliez pas ce week-end

Si vous affichez le code source dans une fenêtre de navigateur, vous verrez le code HTML suivant :

250.png

L'exemple ci-dessus crée un DOMDocument-Object et charge le XML dans "xml_dom.xml" dans cet objet document.

La fonction saveXML() place le document XML interne dans une chaîne afin que nous puissions le sortir.


Traversing XML

Nous souhaitons initialiser l'analyseur XML, charger le XML et parcourir tous les éléments du < note> element :

<?php
 $xmlDoc = new DOMDocument();
 $xmlDoc->load("xml_dom.xml");
 
 $x = $xmlDoc->documentElement;
 foreach ($x->childNodes AS $item)
 {
     print $item->nodeName . " = " . $item->nodeValue . "<br>";
 }
 ?>

Le code ci-dessus affichera :

#text =  
à = Tove
#text =  
de = Jani
#text =
titre = Rappel
#text =
body = Ne m'oubliez pas ce week-end !
#text =

Dans l'exemple ci-dessus, vous voyez qu'il y a des nœuds de texte vides entre chaque élément .

Lorsque XML est généré, il contient souvent des espaces entre les nœuds. L'analyseur XML DOM les traite comme des éléments normaux, ce qui peut parfois poser des problèmes si vous n'y prêtez pas attention.


Pour en savoir plus sur XML DOM, visitez notre tutoriel XML DOM.



Formation continue
||
<?php $xmlDoc = new DOMDocument(); $xmlDoc->load("xml_dom.xml"); print $xmlDoc->saveXML(); ?>
soumettreRéinitialiser le code
  • Recommandations de cours
  • Téléchargement du didacticiel