Os exemplos listados podem incluir o arquivo examples/simplexml-data.php,
que referem-se a uma string XML encontrada no primeiro exemplo
do guia de uso básico.
Exemplo #1 Adiciona atributos e filhos à um elemento SimpleXML
<?php
include 'examples/simplexml-data.php';
$sxe = new SimpleXMLElement($xmlstr); $sxe->addAttribute('tipo', 'documentário');
$filme = $sxe->addChild('filme'); $filme->addChild('titulo', 'PHP2: Mais Estórias de Interpretadores'); $filme->addChild('resumo', 'É tudo é sobre as pessoas que fazem isso funcionar.');
<?xml version="1.0" standalone="yes"?>
<filmes tipo="documentário">
<filme>
<titulo>PHP: Nos Bastidores do Interpretador</titulo>
<personagens>
<personagem>
<nome>Srta. Codificadora</nome>
<ator>Onlivia Actora</ator>
</personagem>
<personagem>
<nome>Sr. Codificador</nome>
<ator>El Actór</ator>
</personagem>
</personagens>
<resumo>
Então, essa linguagem. Se parece com uma linguagem de programação. Ou seria uma
liguagem de scripts? Tudo é revelado nesta emocionante paródia de terror
de um documentário.
</resumo>
<melhores-frases>
<frase>O PHP resolve todos os meus problemas!</frase>
</melhores-frases>
<classificacao tipo="gostei">7</classificacao>
<classificacao tipo="estrelas">5</classificacao>
</filme>
<filme>
<titulo>PHP2: Mais Estórias de Interpretadores</titulo>
<resumo>É tudo é sobre as pessoas que fazem isso funcionar.</resumo>
<personagens>
<personagem>
<nome>Sr. Interpretador</nome>
<ator>Fulano de Tal</ator>
</personagem>
</personagens>
<classificacao tipo="estrelas">5</classificacao>
</filme>
</filmes>
Here is a class with more functions for SimpleXMLElement :
<?php
/**
*
* Extension for SimpleXMLElement
* @author Alexandre FERAUD
*
*/
class ExSimpleXMLElement extends SimpleXMLElement
{
/**
* Add CDATA text in a node
* @param string $cdata_text The CDATA value to add
*/
private function addCData($cdata_text)
{
$node= dom_import_simplexml($this);
$no = $node->ownerDocument;
$node->appendChild($no->createCDATASection($cdata_text));
}
/**
* Create a child with CDATA value
* @param string $name The name of the child element to add.
* @param string $cdata_text The CDATA value of the child element.
*/
public function addChildCData($name,$cdata_text)
{
$child = $this->addChild($name);
$child->addCData($cdata_text);
}
/**
* Add SimpleXMLElement code into a SimpleXMLElement
* @param SimpleXMLElement $append
*/
public function appendXML($append)
{
if ($append) {
if (strlen(trim((string) $append))==0) {
$xml = $this->addChild($append->getName());
foreach($append->children() as $child) {
$xml->appendXML($child);
}
} else {
$xml = $this->addChild($append->getName(), (string) $append);
}
foreach($append->attributes() as $n => $v) {
$xml->addAttribute($n, $v);
}
}
}
}
?>
For this to work properly the attribute xmlns:mobile must be set in the root node, and then used as namespace(third argument) when creating the mobile:mobile child with null as value.