Wie kann ich HTML in JavaScript formatieren/aufräumen/verschönern? I have tried doing a search/replace for angle brackets (<
, >
) and indenting accordingly. Aber natürlich berücksichtigt es nicht, wenn das JS oder CSS usw. im HTML ist.So formatieren/ordnen/verschönern Sie in JavaScript
Der Grund, warum ich dies tun möchte, ist, habe ich einen Inhaltseditor (CMS) gemacht, der sowohl WYSIWYG- als auch Quellcodeansichten hat. Das Problem der vom WYSIWYG-Editor geschriebene Code ist normalerweise eine einzelne Zeile. Daher möchte ich ein JavaScript, das dies bei Bedarf in eine besser lesbare Form formatieren kann.
Hier ist, was ich bisher:
function getIndent(level) {
var result = '',
i = level * 4;
if (level < 0) {
throw "Level is below 0";
}
while (i--) {
result += ' ';
}
return result;
}
function style_html(html) {
html = html.trim();
var result = '',
indentLevel = 0,
tokens = html.split(/</);
for (var i = 0, l = tokens.length; i < l; i++) {
var parts = tokens[i].split(/>/);
if (parts.length === 2) {
if (tokens[i][0] === '/') {
indentLevel--;
}
result += getIndent(indentLevel);
if (tokens[i][0] !== '/') {
indentLevel++;
}
if (i > 0) {
result += '<';
}
result += parts[0].trim() + ">\n";
if (parts[1].trim() !== '') {
result += getIndent(indentLevel) + parts[1].trim().replace(/\s+/g, ' ') + "\n";
}
if (parts[0].match(/^(img|hr|br)/)) {
indentLevel--;
}
} else {
result += getIndent(indentLevel) + parts[0] + "\n";
}
}
return result;
}
manchmal die besten Fragen/Antworten sind Wegthema. – NilsB
@ NilsB Müll Dies ist auf Thema, in der Tat war es bereits als Off-Thema geschlossen und dann wieder wieder geöffnet – Petah
[Hier ist ultra-einfache HTML-Formatierer in JavaScript] (https://jsfiddle.net/buksy/rxucg1gd/) – Buksy