(PHP 5 >= 5.1.2, PHP 7)
SimpleXMLElement::getDocNamespaces — Gibt die im Dokument vorhandenen Namespaces zurück
$recursive
= FALSE
[, bool $from_root
= TRUE
]] ) : arrayGibt die im Dokument vorhandenen Namespaces zurück.
recursive
Sofern angegeben, werden alle Namespaces zurückgegeben, die in Eltern- und Kindknoten deklariert wurden. Andernfalls werden nur die im Wurzelknoten deklarierten Namespaces zurückgegeben.
from_root
Ermöglicht die rekursive Prüfung der Namensräume unter einem Kindknoten statt von der Wurzel des XML-Dokuments.
Die getDocNamespaces-Methode gibt ein Array der Namespaces mit den ihnen zugeordneten URIs zurück.
Beispiel #1 Ermitteln der Dokument-Namespaces
<?php
$xml = <<<XML
<?xml version="1.0" standalone="yes"?>
<people xmlns:p="http://example.org/ns">
<p:person id="1">John Doe</p:person>
<p:person id="2">Susie Q. Public</p:person>
</people>
XML;
$sxe = new SimpleXMLElement($xml);
$namespaces = $sxe->getDocNamespaces();
var_dump($namespaces);
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
array(1) { ["p"]=> string(21) "http://example.org/ns" }
Beispiel #2 Arbeiten mit multiplen Namespaces
<?php
$xml = <<<XML
<?xml version="1.0" standalone="yes"?>
<people xmlns:p="http://example.org/ns" xmlns:t="http://example.org/test">
<p:person t:id="1">John Doe</p:person>
<p:person t:id="2" a:addr="123 Street" xmlns:a="http://example.org/addr">
Susie Q. Public
</p:person>
</people>
XML;
$sxe = new SimpleXMLElement($xml);
$namespaces = $sxe->getDocNamespaces(TRUE);
var_dump($namespaces);
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
array(3) { ["p"]=> string(21) "http://example.org/ns" ["t"]=> string(23) "http://example.org/test" ["a"]=> string(23) "http://example.org/addr" }
Version | Beschreibung |
---|---|
5.4.0 |
from_root Parameter hinzugefügt.
|