我有一个字符串,它表示我想要漂亮打印的非缩进 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 框架和/或插件。我唯一的要求是这要在客户端完成。