Node: Improve DOMParser#parseFromString() polyfill for Node.js

And no need to move imported SVG nodes into document, since we don't have styling in Node.js
This commit is contained in:
Jürg Lehni 2016-01-28 05:13:04 +01:00
parent 662b974104
commit e02e9f4643
2 changed files with 29 additions and 14 deletions

View file

@ -51,9 +51,18 @@ function DOMParser() {
} }
DOMParser.prototype.parseFromString = function(string, contenType) { DOMParser.prototype.parseFromString = function(string, contenType) {
var div = document.createElement('div'); // Create a new document, since we're supposed to always return one.
div.innerHTML = string; var doc = document.implementation.createHTMLDocument(''),
return div.firstChild; body = doc.body,
last;
// Set the body's HTML, then change the DOM according the specs.
body.innerHTML = string;
// Remove all top-level children (<html><head/><body/></html>)
while (last = doc.lastChild)
doc.removeChild(last);
// Insert the first child of the body at the top.
doc.appendChild(body.firstChild);
return doc;
}; };
window.XMLSerializer = XMLSerializer; window.XMLSerializer = XMLSerializer;

View file

@ -186,21 +186,27 @@ new function() {
// nodeNames still. // nodeNames still.
var importers = { var importers = {
'#document': function (node, type, options, isRoot) { '#document': function (node, type, options, isRoot) {
var nodes = node.childNodes; var nodes = node.childNodes,
move = !paper.agent.node;
for (var i = 0, l = nodes.length; i < l; i++) { for (var i = 0, l = nodes.length; i < l; i++) {
var child = nodes[i]; var child = nodes[i],
next;
if (child.nodeType === 1) { if (child.nodeType === 1) {
if (move) {
// NOTE: We need to move the svg node into our current // NOTE: We need to move the svg node into our current
// document, so default styles apply! // document, so default styles apply!
var next = child.nextSibling; next = child.nextSibling;
document.body.appendChild(child); document.body.appendChild(child);
}
var item = importSVG(child, options, isRoot); var item = importSVG(child, options, isRoot);
if (move) {
// After import, we move it back to where it was: // After import, we move it back to where it was:
if (next) { if (next) {
node.insertBefore(child, next); node.insertBefore(child, next);
} else { } else {
node.appendChild(child); node.appendChild(child);
} }
}
return item; return item;
} }
} }