Работа над XmlParser
This commit is contained in:
@@ -399,6 +399,8 @@ class XmlParser extends NodeBase {
|
|||||||
|
|
||||||
const nodesToString = (nodes, depth = 0) => {
|
const nodesToString = (nodes, depth = 0) => {
|
||||||
let result = '';
|
let result = '';
|
||||||
|
|
||||||
|
const indent = '\n' + ' '.repeat(depth);
|
||||||
let lastType = 0;
|
let lastType = 0;
|
||||||
|
|
||||||
for (const n of nodes) {
|
for (const n of nodes) {
|
||||||
@@ -424,22 +426,23 @@ class XmlParser extends NodeBase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
open = `<${node.name}${attrs}>`;
|
|
||||||
|
open = (format && lastType !== TEXT ? indent : '');
|
||||||
|
open += `<${node.name}${attrs}>`;
|
||||||
|
|
||||||
if (node.value)
|
if (node.value)
|
||||||
body = nodesToString(node.value, depth + 2);
|
body = nodesToString(node.value, depth + 2);
|
||||||
close = `</${node.name}>`;
|
|
||||||
|
|
||||||
if (format) {
|
close = (format && deepType && deepType !== TEXT ? indent : '');
|
||||||
open = (lastType !== TEXT ? '\n' + ' '.repeat(depth) : '') + open;
|
close += `</${node.name}>`;
|
||||||
close = (deepType === NODE ? '\n' + ' '.repeat(depth) : '') + close;
|
|
||||||
}
|
|
||||||
} else if (node.type === TEXT) {
|
} else if (node.type === TEXT) {
|
||||||
body = node.value || '';
|
body = node.value || '';
|
||||||
} else if (node.type === CDATA) {
|
} else if (node.type === CDATA) {
|
||||||
body = `<![CDATA[${node.value || ''}]]>`;
|
body = (format && lastType !== TEXT ? indent : '');
|
||||||
|
body += `<![CDATA[${node.value || ''}]]>`;
|
||||||
} else if (node.type === COMMENT) {
|
} else if (node.type === COMMENT) {
|
||||||
body = `<!--${node.value || ''}-->`;
|
body = (format && lastType !== TEXT ? indent : '');
|
||||||
|
body += `<!--${node.value || ''}-->`;
|
||||||
}
|
}
|
||||||
|
|
||||||
result += `${open}${body}${close}`;
|
result += `${open}${body}${close}`;
|
||||||
@@ -528,9 +531,23 @@ class XmlParser extends NodeBase {
|
|||||||
};
|
};
|
||||||
|
|
||||||
const onCdata = (tagData, cutCounter, cutTag) => {// eslint-disable-line no-unused-vars
|
const onCdata = (tagData, cutCounter, cutTag) => {// eslint-disable-line no-unused-vars
|
||||||
|
if (ignoreNode)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (!node.value)
|
||||||
|
node.value = [];
|
||||||
|
|
||||||
|
node.value.push(this.createCdata(tagData).raw);
|
||||||
}
|
}
|
||||||
|
|
||||||
const onComment = (tagData, cutCounter, cutTag) => {// eslint-disable-line no-unused-vars
|
const onComment = (tagData, cutCounter, cutTag) => {// eslint-disable-line no-unused-vars
|
||||||
|
if (ignoreNode)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (!node.value)
|
||||||
|
node.value = [];
|
||||||
|
|
||||||
|
node.value.push(this.createComment(tagData).raw);
|
||||||
}
|
}
|
||||||
|
|
||||||
sax.parseSync(xmlString, {
|
sax.parseSync(xmlString, {
|
||||||
|
|||||||
Reference in New Issue
Block a user