使用javascript打印XML的漂亮
2022-08-30 02:40:24
我有一个字符串,它表示一个非缩进的XML,我想打印它。例如:
<root><node/></root>
应变为:
<root>
<node/>
</root>
语法突出显示不是必需的。为了解决这个问题,我首先转换 XML 以添加回车符和空格,然后使用 pre 标记输出 XML。为了添加新行和空格,我编写了以下函数:
function formatXml(xml) {
var formatted = '';
var reg = /(>)(<)(\/*)/g;
xml = xml.replace(reg, '$1\r\n$2$3');
var pad = 0;
jQuery.each(xml.split('\r\n'), function(index, node) {
var indent = 0;
if (node.match( /.+<\/\w[^>]*>$/ )) {
indent = 0;
} else if (node.match( /^<\/\w/ )) {
if (pad != 0) {
pad -= 1;
}
} else if (node.match( /^<\w[^>]*[^\/]>.*$/ )) {
indent = 1;
} else {
indent = 0;
}
var padding = '';
for (var i = 0; i < pad; i++) {
padding += ' ';
}
formatted += padding + node + '\r\n';
pad += indent;
});
return formatted;
}
然后,我像这样调用该函数:
jQuery('pre.formatted-xml').text(formatXml('<root><node1/></root>'));
这对我来说非常好,但是当我编写以前的函数时,我认为一定有更好的方法。所以我的问题是,你知道有没有更好的方法来给定一个XML字符串来漂亮的打印它在html页面中?欢迎任何可以完成这项工作的javascript框架和/或插件。我唯一的要求是在客户端完成此操作。