diff --git a/dom.js b/dom.js
index b13b371..9776723 100644
--- a/dom.js
+++ b/dom.js
@@ -368,6 +368,9 @@ Node.prototype = {
},
lookupPrefix:function(namespaceURI){
var el = this;
+ if(el.nodeType == DOCUMENT_NODE){
+ el = el.documentElement;
+ }
while(el){
var map = el._nsMap;
//console.dir(map)
@@ -378,13 +381,16 @@ Node.prototype = {
}
}
}
- el = el.nodeType == ATTRIBUTE_NODE?el.ownerDocument : el.parentNode;
+ el = el.nodeType == ATTRIBUTE_NODE?el.ownerElement : el.parentNode;
}
return null;
},
// Introduced in DOM Level 3:
lookupNamespaceURI:function(prefix){
var el = this;
+ if(el.nodeType == DOCUMENT_NODE){
+ el = el.documentElement;
+ }
while(el){
var map = el._nsMap;
//console.dir(map)
@@ -393,7 +399,7 @@ Node.prototype = {
return map[prefix] ;
}
}
- el = el.nodeType == ATTRIBUTE_NODE?el.ownerDocument : el.parentNode;
+ el = el.nodeType == ATTRIBUTE_NODE?el.ownerElement : el.parentNode;
}
return null;
},
diff --git a/test/parse/namespace.js b/test/parse/namespace.js
index a06248c..5342c6b 100644
--- a/test/parse/namespace.js
+++ b/test/parse/namespace.js
@@ -28,5 +28,13 @@ wows.describe('XML Namespace Parse').addBatch({
console.assert(root.firstChild.namespaceURI=='http://p.com')
console.assert(root.lastChild.namespaceURI=='http://test.com')
console.assert(root.firstChild.nextSibling.lookupNamespaceURI('p') == 'http://test.com')
- }
-}).run(); // Run it
\ No newline at end of file
+ },
+ 'performing a lookup from a document node': function () {
+ var documentNode = new DOMParser().parseFromString('','text/xml');
+ console.assert(documentNode.lookupNamespaceURI('') == 'http://test.com')
+ },
+ 'performing a lookup from an attribute node': function () {
+ var documentNode = new DOMParser().parseFromString('','text/xml');
+ console.assert(documentNode.documentElement.getAttributeNode('attr').lookupNamespaceURI('') == 'http://test.com')
+ }
+}).run(); // Run it