Skip to content

Instantly share code, notes, and snippets.

@tylerthebuildor
Created April 29, 2013 18:11
Show Gist options
  • Save tylerthebuildor/5483512 to your computer and use it in GitHub Desktop.
Save tylerthebuildor/5483512 to your computer and use it in GitHub Desktop.
Adds span elements to parts of JSON string for post CSS manipulation.
function syntaxHighlight(json) {
if (typeof json != 'string') {
json = JSON.stringify(json, undefined, 2);
}
json = json.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;');
return json.replace(/("(\\u[a-zA-Z0-9]{4}|\\[^u]|[^\\"])*"(\s*:)?|\b(true|false|null)\b|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?)/g, function (match) {
var cls = 'number';
if (/^"/.test(match)) {
if (/:$/.test(match)) {
cls = 'key';
} else {
cls = 'string';
}
} else if (/true|false/.test(match)) {
cls = 'boolean';
} else if (/null/.test(match)) {
cls = 'null';
}
return '<span class="' + cls + '">' + match + '</span>';
});
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment