私はきれいに印刷したいインデントされていない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>'));
これは完璧に機能しますが、前の関数を書いているときに、もっと良い方法があるはずだと思いました。だから私の質問は、HTML文字列を与えてHTMLページにきれいに印刷するためのより良い方法を知っていますか?仕事をすることができるJavaScriptフレームワークやプラグインは大歓迎です。私の唯一の要件は、これがクライアント側で行われることです。