NamedNodeMap: setNamedItemNS() Methode
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
Die setNamedItemNS()
Methode der NamedNodeMap
Schnittstelle
fügt das durch seinen Namen identifizierte Attr
in die Map ein.
Wenn sich bereits ein Attr
mit demselben Namen in der Map befindet,
wird es ersetzt.
Hinweis:
Diese Methode ist ein Alias von setNamedItem()
, Sie können sie
austauschbar verwenden.
Syntax
setNamedItemNS(attr)
Parameter
attr
-
Das Attribut, das in die Map eingefügt werden soll.
Rückgabewert
Gibt das alte Attribut zurück, wenn es ersetzt wurde, oder null
, wenn das Attribut neu ist.
Ausnahmen
InUseAttributeError
DOMException
-
Wird ausgelöst, wenn das Attribut noch Teil einer anderen Map ist.
Beispiel
<span ob:one="one"></span>
<pre></pre>
const parser = new DOMParser();
// ob:one in <span> is not in a namespace, while ob:one in <warning>, is.
const xmlString =
'<warning ob:one="test" xmlns:ob="http://www.example.com/ob">Beware!</warning>';
const doc = parser.parseFromString(xmlString, "application/xml");
const span = document.querySelector("span");
const pre = document.querySelector("pre");
const warning = doc.querySelector("warning");
const attrMap = span.attributes;
let result = `The '<span>' element initially contains ${attrMap.length} attribute.\n\n`;
result += "We remove `one` from '<span>' and adds it to '<pre>'.\n";
const one = warning.attributes.removeNamedItemNS(
"http://www.example.com/ob",
"one",
);
attrMap.setNamedItemNS(one);
result += `The '<span>' element now contains ${span.attributes.length} attributes:\n\n`;
result += "Prefix\tLocal name\tQualified name\n";
result += "=========================================\n";
for (const attr of attrMap) {
result += `${attr.prefix}\t${attr.localName}\t\t${attr.name}\n`;
}
pre.textContent = result;
Spezifikationen
Specification |
---|
DOM # dom-namednodemap-setnameditemns |
Browser-Kompatibilität
BCD tables only load in the browser