最新消息:Welcome to the puzzle paradise for programmers! Here, a well-designed puzzle awaits you. From code logic puzzles to algorithmic challenges, each level is closely centered on the programmer's expertise and skills. Whether you're a novice programmer or an experienced tech guru, you'll find your own challenges on this site. In the process of solving puzzles, you can not only exercise your thinking skills, but also deepen your understanding and application of programming knowledge. Come to start this puzzle journey full of wisdom and challenges, with many programmers to compete with each other and show your programming wisdom! Translated with DeepL.com (free version)

javascript - Difference between setAttribute and setAttributeNS(null, - Stack Overflow

matteradmin22PV0评论

What is the difference between calling setAttribute and setAttributeNS with null as the namespace parameter?

Also is there an issue with using getAttribute() and then setAttributeNS ?

What is the difference between calling setAttribute and setAttributeNS with null as the namespace parameter?

Also is there an issue with using getAttribute() and then setAttributeNS ?

Share Improve this question asked Jan 28, 2016 at 9:46 SPlattenSPlatten 5,74813 gold badges72 silver badges137 bronze badges
Add a comment  | 

4 Answers 4

Reset to default 16

setAttribute() is a DOM 1 function. setAttributeNS() is a DOM 2 function that resolves the problem of conflicting tag or attribute names by specifying the xmlns namespace that should apply to the tag/attribute in the first argument.

If an attribute does not have a defined namespace prefix, the first argument must be null. You could use setAttribute() but for consistency it is advisable to stick to setAttributeNS(). See:

https://developer.mozilla.org/en/docs/Web/SVG/Namespaces_Crash_Course#Scripting_in_namespaced_XML

"However, note carefully: the Namespaces in XML 1.1 recommendation states that the namespace name for attributes without a prefix does not have a value. In other words, although the attributes belong to the namespace of the tag, you do not use the tag's namespace name. Instead, you must use null as the namespace name for unqualified (prefixless) attributes."

The setAttributeNS method is an XML method, and will not work with HTML elements.

Here's an explanation in English, from the MDN docs:

// Given:
//   <div id="div1" xmlns:special="http://www.mozilla.org/ns/specialspace"
//     special:specialAlign="utterleft" width="200px" /> 

d = document.getElementById("div1"); 
d.removeAttributeNS("http://www.mozilla.org/ns/specialspace", "specialAlign"); 

// Now:
//   <div id="div1" width="200px" />

So from this, it appears that xmlns:special="http://www.mozilla.org/ns/specialspace" is a declaration of the namespace special, which is then used to contextualize special:specialAlign.

setAttributeNS is used for specifying the namespace and adds a new attribute with a namespace. NS represent that. Also it requires three parameters

element.setAttributeNS(ns,name,value)

ns  :namespace URI of the attribute to set
name:Name of the attribute to set
value:Value of the attribute to set

setAttribute(name,value) which is use to add a new attribute or change the value of existing attribute.

Articles related to this article

Post a comment

comment list (0)

  1. No comments so far