ฉันมีสตริงที่แสดงถึง XML ที่ไม่เยื้องซึ่งฉันต้องการพิมพ์แบบสวย ๆ ตัวอย่างเช่น:
<root><node/></root>
ควรจะกลายเป็น:
<root>
<node/>
</root>
การเน้นไวยากรณ์ไม่ใช่ข้อกำหนด ในการแก้ไขปัญหาขั้นแรกฉันจะแปลง XML เพื่อเพิ่มการส่งคืนค่าขนส่งและช่องว่างสีขาวจากนั้นใช้แท็กก่อนเพื่อส่งออก 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 หรือไม่? ยินดีต้อนรับเฟรมเวิร์กจาวาสคริปต์และ / หรือปลั๊กอินที่สามารถทำงานได้ ข้อกำหนดเดียวของฉันคือต้องทำในฝั่งไคลเอ็นต์