使用正則表達式的格式化与高亮显示json字符串
使用正則表達式的格式化与高亮显示json字符串
首先是对输入进行转换。假设是对象则转化为规范的json字符串,不是对象时。先将字符串转化为对象(防止不规范的字符串),然后再次转化为json串。当中json为输入。
if (typeof json !== 'string') {
json = JSON.stringify(json);
} else {
json = JSON.parse(json);
json = JSON.stringify(json);
}
等规范完数据之后对字符串进行标记,为了后面的切分、又一次组合
这里有几个地方要加入标记,包含大括号、小括号的前后和逗号的后面都要加入标记,我这里使用的是换行\r\n(这样在命令行下測试时效果会比較好看)。
// 在大括号前后加入换行
reg = /([\{\}])/g;
json = json.replace(reg, '\r\n$1\r\n');
// 中括号前后加入换行
reg = /([\[\]])/g;
json = json.replace(reg, '\r\n$1\r\n');
// 逗号后面加入换行
reg = /(\,)/g;
json = json.replace(reg, '$1\r\n');
加入完毕标记之后就要做一些优化处理,去掉多余的换行、去掉逗号前面的换行,这样做是为了在切分是免得出现空串浪费一次循环处理,最后在冒号后面加入空格,看起来更美丽。
// 去除多余的换行 reg = /(\r\n\r\n)/g; json = json.replace(reg, '\r\n'); // 逗号前面的换行去掉 reg = /\r\n\,/g; json = json.replace(reg, ','); //冒号前面缩进 reg = /\:/g; json = json.replace(reg, ': ');
接下来就是对这个初步处理过的串进行进一步处理了,我会在function(index, node) {}函数中加入逻辑,对每个切分单元进行处理。包含缩进和美化格式。
$.each(json.split('\r\n'), function(index, node) {});
首先说下缩进,缩进的方法非常easy,遇到{、[符号时缩进添加1,遇到}、]符号时缩进降低1,否则缩进量不变。
//这里遇到{、[时缩进等级加1。遇到}、]时缩进等级减1,没遇到时缩进等级不变
if (node.match(/\{$/) || node.match(/\[$/)) {
indent = 1;
} else if (node.match(/\}/) || node.match(/\]/)) {
if (pad !== 0) {
pad -= 1;
}
} else {
indent = 0;
}
完毕缩进后就该美化高亮显示代码了,这里要用到几个css规则。以下能够看到,对切分单元进行高亮显示的时候这里用正则进行推断,假设匹配到大括号标记为对象class、中括号标记为数组class、属性名称、属性值。一次对这些进行css规则加入,加入完毕之后拼接起来就能够了。
.ObjectBrace{color:#00AA00;font-weight:bold;}
.ArrayBrace{color:#0033FF;font-weight:bold;}
.PropertyName{color:#CC0000;font-weight:bold;}
.String{color:#007777;}
.Number{color:#AA00AA;}
.Comma{color:#000000;font-weight:bold;}
//加入代码高亮
node = node.replace(/([\{\}])/g,"<span class='ObjectBrace'>$1</span>");
node = node.replace(/([\[\]])/g,"<span class='ArrayBrace'>$1</span>");
node = node.replace(/(\".*\")(\:)(.*)(\,)?
/g,"<span class='PropertyName'>$1</span>$2$3$4");
node = node.replace(/\"([^"]*)\"(\,)?$/g,"<span class='String'>\"$1\"</span><span class='Comma'>$2</span>");
node = node.replace(/(-?
\d+)(\,)?$/g,"<span class='Number'>$1</span><span class='Comma'>$2</span>");
最后我们看看完整的方法代码(这里我使用了jquery类库)。以及測试地址:
要对jsonstr进行美化,这样就能够了APP.format(jsonstr),直接输出至<pre></pre>标签中就能够看到效果。
以下是一个測试地址,http://iforever.sinaapp.com/ 能够进去试一下。看看完整的源码
<script>
var APP=function(){
var format=function(json){
var reg=null,
result='';
pad=0,
PADDING=' ';
if (typeof json !== 'string') {
json = JSON.stringify(json);
} else {
json = JSON.parse(json);
json = JSON.stringify(json);
}
// 在大括号前后加入换行
reg = /([\{\}])/g;
json = json.replace(reg, '\r\n$1\r\n');
// 中括号前后加入换行
reg = /([\[\]])/g;
json = json.replace(reg, '\r\n$1\r\n');
// 逗号后面加入换行
reg = /(\,)/g;
json = json.replace(reg, '$1\r\n');
// 去除多余的换行
reg = /(\r\n\r\n)/g;
json = json.replace(reg, '\r\n');
// 逗号前面的换行去掉
reg = /\r\n\,/g;
json = json.replace(reg, ',');
//冒号前面缩进
reg = /\:/g;
json = json.replace(reg, ': ');
//对json依照换行进行切分然后处理每个小块
$.each(json.split('\r\n'), function(index, node) {
var i = 0,
indent = 0,
padding = '';
//这里遇到{、[时缩进等级加1,遇到}、]时缩进等级减1,没遇到时缩进等级不变
if (node.match(/\{$/) || node.match(/\[$/)) {
indent = 1;
} else if (node.match(/\}/) || node.match(/\]/)) {
if (pad !== 0) {
pad -= 1;
}
} else {
indent = 0;
}
//padding保存实际的缩进
for (i = 0; i < pad; i++) {
padding += PADDING;
}
//加入代码高亮
node = node.replace(/([\{\}])/g,"<span class='ObjectBrace'>$1</span>");
node = node.replace(/([\[\]])/g,"<span class='ArrayBrace'>$1</span>");
node = node.replace(/(\".*\")(\:)(.*)(\,)?/g,"<span class='PropertyName'>$1</span>$2$3$4");
node = node.replace(/\"([^"]*)\"(\,)?$/g,"<span class='String'>\"$1\"</span><span class='Comma'>$2</span>");
node = node.replace(/(-?\d+)(\,)?$/g,"<span class='Number'>$1</span><span class='Comma'>$2</span>");
result += padding + node + '<br>';
pad += indent;
});
return result;
};
return {
"format":format,
};
}();
</script>
怎么样,json字符串是不是美观了非常多呢,超级有用吧。这么好的东东。当然不能独享,这里推荐给小伙伴们。
參考来源:
使用正則表達式的格式化与高亮显示json字符串
http://www.lai18.com/content/351722.html
延伸阅读
1JavaScript正則表達式中的ignoreCase属性使用具体解释
2具体解释JavaScript正則表達式中的global属性的使用
3简述JavaScript的正則表達式中test()方法的使用
5JavaScript正則表達式之multiline属性的应用
8【JavaScript】利用正則表達式检查输入框输入的是否为网址
11javascript使用正則表達式实现去掉空格之后的字符
14javascript正則表達式之search()使用方法实例
15javascript正則表達式使用replace()替换手机号的方法
28javascript正則表達式參数/g与/i及/gi的使用指南
34JS使用replace()方法和正則表達式进行字符串的搜索与替换实例
40js正則表達式中test,exec,match方法的差别说明
45正則表達式中特殊符号及正則表達式的几种方法总结(replace,test,search)
60Jquery Validate 正則表達式有用验证代码大全
62怎样使用Javascript正則表達式来格式化XML内容
66有用的JS正則表達式(手机号码/IP正则/邮编正则/电话等)
68JavaScript高级程序设计(第3版)学习笔记12 js正則表達式
73js正則表達式
75javascript 进阶篇1 正則表達式,cookie管理。userData
76jQuery源代码分析-02正則表達式 RegExp 经常使用正則表達式
93javascript 获取链接文件地址中第一个斜线内的正則表達式
94用正則表達式 动态创建/添加css style script 兼容IE firefox
使用正則表達式的格式化与高亮显示json字符串的更多相关文章
- JavaScript正則表達式知识汇总
Js 正則表達式知识汇总 正則表達式: 1.什么是RegExp?RegExp是正則表達式的缩写.RegExp 对象用于规定在文本中检索的内容. 2.定义RegExp:var +变量名=new RegE ...
- Python正則表達式:怎样使用正則表達式
正則表達式(简称RE)本质上能够看作一个小的.高度专业化的编程语言,在Python中能够通过re模块使用它.使用正則表達式,你须要为想要匹配的字符串集合指定一套规则,字符串集合能够包括英文句子.e-m ...
- python之路-------字符串与正則表達式
1.1.#####去掉字符串中的转义符string.strip() print "hello\tworld\n" >>> word="\thello w ...
- 深入浅出理解iOS经常使用的正則表達式—基础篇[Foundation]
參考资料:cocoachina的zys475481075的文章 几个单词 Regular ['regjʊlə]adj. 定期的:有规律的 Expression[ɪk'spreʃ(ə)n; ek-] n ...
- JAVA学习第六十五课 — 正則表達式
正則表達式:主要应用于操作字符串.通过一些特定的符号来体现 举例: QQ号的校验 6~9位.0不得开头.必须是数字 String类中有matches方法 matches(String regex) 告 ...
- javascript正則表達式
定义一个正則表達式 能够用字面量 var regex = /xyz/; var regex = /xyz/i; 也能够用构造函数 var regex = new RegExp('xyz'); var ...
- VB.NET利用正則表達式巧妙限制字符输入
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/u010028869/article/details/37913867 在通常的程序设计中.对 ...
- Linux正則表達式-反复出现的字符
星号(*)元字符表示它前面的正則表達式能够出现零次或多次.也就是说,假设它改动了单个字符.那么该字符能够在那里也能够不在那里,而且假设它在那里,那可能会不止出现一个.能够使用星号元字符匹配出如今引號中 ...
- 轻松学习之Linux教程六 正則表達式具体解释
本系列文章由@超人爱因斯坦出品.转载请注明出处. 作者:超人爱因斯坦 个人站点:http://www.hpw123.net 文章链接:http://hpw123.net/a/L ...
随机推荐
- IOS学习笔记37——ViewController生命周期详解
在我之前的学习笔记中讨论过ViewController,过了这么久,对它也有了新的认识和体会,ViewController是我们在开发过程中碰到最多的朋友,今天就来好好认识一下它.ViewContro ...
- qemu-img命令
qemu-img是QEMU的磁盘管理工具,在qemu-kvm源码编译后就会默认编译好qemu-img这个二进制文件.qemu-img也是QEMU/KVM使用过程中一个比较重要的工具,本节对其用法和实践 ...
- validate 常用的输入框校验
记录一下angular可以直接用的输入框校验器,外加一个国内手机号码的校验 <!DOCTYPE html> <html> <head> <meta chars ...
- Tomcat server.xml配置文件
server.xml配置文件: <?xml version="1.0" encoding="UTF-8"?> <!-- Licensed to ...
- MySQL 初识
一.MySQL介绍: MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品.MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,M ...
- Android开发——短信电话拦截/接听电话
1.短信拦截 首先需要声明的是,Android4.4版本以上,如果想做到短信拦截,必须成为default sms,把所有短信相关的功能都包揽了,然后再做短信拦截.但这种做法,适配性和兼容性的工作是非常 ...
- Python编译错误总结
1.TypeError: object() takes no parameters 如果你出现了这个报错,请检查你的__init__函数名或者其定义有没有写错.一般是把__init__写成了__int ...
- Python工程师面试题目
1.请尽可能列举python列表的成员方法,并给出一下列表操作的答案: len() 返回列表中的元素数量. max() 返回列表中的最大元素.最大元素的判断依据是列表中的对象类型.数字列表中的最大元素 ...
- python009 Python3 列表
Python3 列表序列是Python中最基本的数据结构.序列中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推.Python有6个序列的内置类型,但最常见的是 ...
- Spring Boot Reactive Streams
1 响应式编程规范 目标:provide a standard for asynchronous stream processing with non-blocking backpressure ht ...