1. 实时性(Live): NamedNodeMap 是实时的,它会随着元素节点属性的变化而自动更新。
2. 键值对: NamedNodeMap 中的属性以键值对的形式存在,其中键是属性的名称,值是对应的属性节点。
3. 只读(Read-only): NamedNodeMap 是只读的,你不能直接修改其中的属性节点。
4. length 属性: NamedNodeMap 具有 length 属性,表示其中属性的数量。
5. getNamedItem(name) 方法: 通过 getNamedItem(name) 方法可以获取指定名称的属性节点。
6. setNamedItem(node) 方法: 通过 setNamedItem(node) 方法可以向 NamedNodeMap 中添加一个属性节点。
7. removeNamedItem(name) 方法: 通过 removeNamedItem(name) 方法可以从 NamedNodeMap 中移除指定名称的属性节点。
8. item() 方法: 通过 item(index) 方法可以获取 NamedNodeMap 中指定索引位置的属性节点。
var element = document.getElementById("exampleElement");
var attributeMap = element.attributes;
// 遍历 NamedNodeMap
for (var i = 0; i < attributeMap.length; i++) {
var attribute = attributeMap[i];
console.log(attribute.name + ": " + attribute.value);
}
// 使用 getNamedItem 获取指定名称的属性节点
var idAttribute = attributeMap.getNamedItem("id");
console.log(idAttribute.name + ": " + idAttribute.value);
// 使用 setNamedItem 向 NamedNodeMap 中添加属性节点
var newAttribute = document.createAttribute("newAttr");
newAttribute.value = "New Value";
attributeMap.setNamedItem(newAttribute);
// 使用 removeNamedItem 移除指定名称的属性节点
attributeMap.removeNamedItem("existingAttr");
// 使用 item() 方法获取指定索引位置的属性节点
var firstAttribute = attributeMap.item(0);
在上述示例中,element.attributes 返回一个 NamedNodeMap,其中包含元素节点的所有属性。通过遍历 NamedNodeMap,你可以访问每个属性的名称和值。同样,NamedNodeMap 是实时的,如果元素的属性发生变化,attributeMap 也会自动更新。
转载请注明出处:http://www.pingtaimeng.com/article/detail/14578/XML DOM