Attrinterface represents an attribute in an
Elementobject. Typically the allowable values for the attribute are defined in a document type definition.
Attrobjects inherit the
Nodeinterface, but since they are not actually child nodes of the element they describe, the DOM does not consider them part of the document tree. Thus, the
Attrobjects. The DOM takes the view that attributes are properties of elements rather than having a separate identity from the elements they are associated with; this should make it more efficient to implement such features as default attributes associated with all elements of a given type. Furthermore,
Attrnodes may not be immediate children of a
DocumentFragment. However, they can be associated with
Elementnodes contained within a
DocumentFragment. In short, users and implementors of the DOM need to be aware that
Attrnodes have some things in common with other objects inheriting the
Nodeinterface, but they also are quite distinct.
The attribute's effective value is determined as follows: if this attribute has been explicitly assigned any value, that value is the attribute's effective value; otherwise, if there is a declaration for this attribute, and that declaration includes a default value, then that default value is the attribute's effective value; otherwise, the attribute does not exist on this element in the structure model until it has been explicitly added. Note that the
nodeValueattribute on the
Attrinstance can also be used to retrieve the string version of the attribute's value(s).
In XML, where the value of an attribute can contain entity references, the child nodes of the
Attrnode may be either
EntityReferencenodes (when these are in use; see the description of
EntityReferencefor discussion). Because the DOM Core is not aware of attribute types, it treats all attribute values as simple strings, even if the DTD or schema declares them as having tokenized types.
See also the Document Object Model (DOM) Level 2 Core Specification.