SimpleXMLElement::getDocNamespaces
(PHP 5 >= 5.1.2, PHP 7, PHP 8)
SimpleXMLElement::getDocNamespaces — Retorna um namespace declarado no documento
Descrição
public SimpleXMLElement::getDocNamespaces(bool
$recursive
= false
, bool $fromRoot
= true
): array|falseRetorna um namespace declarado no documento
Parâmetros
recursive
-
Se especificado, retorna todos os namespaces declarados no nó pai e nos nós filhos. De outra forma, retornará apenas os namespaces declarados no nó raiz.
fromRoot
-
Permite verificar recursivamente os namespaces sob um nó filho em vez do nó raiz do documento XML.
Valor Retornado
O método getDocNamespaces
retorna uma array
com os namespaces associados às suas URIs.
Exemplos
Example #1 Pega os namespaces do documento
<?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);
?>
O exemplo acima produzirá:
array(1) { ["p"]=> string(21) "http://example.org/ns" }
Example #2 Trabalhando com múltiplos 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);
?>
O exemplo acima produzirá:
array(3) { ["p"]=> string(21) "http://example.org/ns" ["t"]=> string(23) "http://example.org/test" ["a"]=> string(23) "http://example.org/addr" }
Veja Também
- SimpleXMLElement::getNamespaces() - Retorna os namespaces utilizados no documento
- SimpleXMLElement::registerXPathNamespace() - Cria um prefixo/namespace de contexto para a próxima consulta XPath