PHPerKaigi 2025

DOMDocument::createElementNS

(PHP 5, PHP 7, PHP 8)

DOMDocument::createElementNS Cria novo nó de elemento com um namespace associado

Descrição

public DOMDocument::createElementNS(?string $namespace, string $qualifiedName, string $value = ""): DOMElement|false

Esta função cria um novo nó de elemento com um namespace associado. Este nó não aparecerá no documento a menos que seja inserido, por exemplo, com DOMNode::appendChild().

Parâmetros

namespace

O URI do namespace.

qualifiedName

O nome qualificado do elemento, como prefixo:nomedatag.

value

O valor do elemento. Por padrão, um elemento vazio será criado. Pode-se também pode definir o valor posteriormente com DOMElement::$nodeValue.

Valor Retornado

O novo DOMElement ou false se ocorrer um erro.

Erros/Exceções

DOM_INVALID_CHARACTER_ERR

Gerado se qualifiedName contiver um caractere inválido.

DOM_NAMESPACE_ERR

Gerado se qualifiedName for um nome qualificado malformado.

Exemplos

Exemplo #1 Criando um novo elemento e inserindo-o como raiz

<?php

$dom
= new DOMDocument('1.0', 'utf-8');

$element = $dom->createElementNS('http://www.example.com/XFoo', 'xfoo:test', 'Este é o elemento raiz!');

// Inserimos o novo elemento como raiz (filho do documento)
$dom->appendChild($element);

echo
$dom->saveXML();
?>

O exemplo acima produzirá:

<?xml version="1.0" encoding="utf-8"?>
<xfoo:test xmlns:xfoo="http://www.example.com/XFoo">Este é o elemento raiz!</xfoo:test>

Exemplo #2 Um exemplo de prefixo de namespace

<?php
$doc
= new DOMDocument('1.0', 'utf-8');
$doc->formatOutput = true;
$root = $doc->createElementNS('http://www.w3.org/2005/Atom', 'element');
$doc->appendChild($root);
$root->setAttributeNS('http://www.w3.org/2000/xmlns/' ,'xmlns:g', 'http://base.google.com/ns/1.0');
$item = $doc->createElementNS('http://base.google.com/ns/1.0', 'g:item_type', 'house');
$root->appendChild($item);

echo
$doc->saveXML(), "\n";

echo
$item->namespaceURI, "\n"; // Outputs: http://base.google.com/ns/1.0
echo $item->prefix, "\n"; // Outputs: g
echo $item->localName, "\n"; // Outputs: item_type
?>

O exemplo acima produzirá:

<?xml version="1.0" encoding="utf-8"?>
<element xmlns="http://www.w3.org/2005/Atom" xmlns:g="http://base.google.com/ns/1.0">
  <g:item_type>house</g:item_type>
</element>

http://base.google.com/ns/1.0
g
item_type

Veja Também

adicione uma nota

Notas Enviadas por Usuários (em inglês) 1 note

up
2
Martin
13 years ago
To avoid multiple xmlns re-declaration, make sure you appending ElementNS into actual DOMDocument tree (not into some currently-assembed derelict element).
To Top