From 628cd35ce3a8edcb7a3ceda6f6af9ad7aa7fa794 Mon Sep 17 00:00:00 2001 From: Martin Middel Date: Fri, 23 Jun 2017 11:52:38 +0200 Subject: [PATCH] Fix lookupNamespaceURI / lookupPrefix for Document / Attributes. This fixes #213. --- dom.js | 10 ++++++++-- test/parse/namespace.js | 10 +++++++++- 2 files changed, 17 insertions(+), 3 deletions(-) diff --git a/dom.js b/dom.js index b13b371..cb5f286 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..f15b761 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') + }, + '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 \ No newline at end of file +}).run(); // Run it