使用正則表達式的格式化与高亮显示json字符串

json字符串非常实用,有时候一些后台接口返回的信息是字符串格式的,可读性非常差,这个时候要是有个能够格式化并高亮显示json串的方法那就好多了,以下看看一个正則表達式完毕的json字符串的格式化与高亮显示



首先是对输入进行转换。假设是对象则转化为规范的json字符串,不是对象时。先将字符串转化为对象(防止不规范的字符串),然后再次转化为json串。当中json为输入。

  1. if (typeof json !== 'string') {
  2.  
  3. json = JSON.stringify(json);
  4.  
  5. } else {
  6.  
  7. json = JSON.parse(json);
  8.  
  9. json = JSON.stringify(json);
  10.  
  11. }

等规范完数据之后对字符串进行标记,为了后面的切分、又一次组合



这里有几个地方要加入标记,包含大括号、小括号的前后和逗号的后面都要加入标记,我这里使用的是换行\r\n(这样在命令行下測试时效果会比較好看)。

  1. // 在大括号前后加入换行
  2.  
  3. reg = /([\{\}])/g;
  4.  
  5. json = json.replace(reg, '\r\n$1\r\n');
  6.  
  7. // 中括号前后加入换行
  8.  
  9. reg = /([\[\]])/g;
  10.  
  11. json = json.replace(reg, '\r\n$1\r\n');
  12.  
  13. // 逗号后面加入换行
  14.  
  15. reg = /(\,)/g;
  16.  
  17. json = json.replace(reg, '$1\r\n');

加入完毕标记之后就要做一些优化处理,去掉多余的换行、去掉逗号前面的换行,这样做是为了在切分是免得出现空串浪费一次循环处理,最后在冒号后面加入空格,看起来更美丽。

  1. // 去除多余的换行
  2.  
  3. reg = /(\r\n\r\n)/g;
  4.  
  5. json = json.replace(reg, '\r\n');
  6.  
  7. // 逗号前面的换行去掉
  8.  
  9. reg = /\r\n\,/g;
  10.  
  11. json = json.replace(reg, ',');
  12.  
  13. //冒号前面缩进
  14.  
  15. reg = /\:/g;
  16.  
  17. json = json.replace(reg, ': ');

接下来就是对这个初步处理过的串进行进一步处理了,我会在function(index, node) {}函数中加入逻辑,对每个切分单元进行处理。包含缩进和美化格式。

  1. $.each(json.split('\r\n'), function(index, node) {});

首先说下缩进,缩进的方法非常easy,遇到{、[符号时缩进添加1,遇到}、]符号时缩进降低1,否则缩进量不变。

  1. //这里遇到{、[时缩进等级加1。遇到}、]时缩进等级减1,没遇到时缩进等级不变
  2.  
  3. if (node.match(/\{$/) || node.match(/\[$/)) {
  4.  
  5. indent = 1;
  6.  
  7. } else if (node.match(/\}/) || node.match(/\]/)) {
  8.  
  9. if (pad !== 0) {
  10.  
  11. pad -= 1;
  12.  
  13. }
  14.  
  15. } else {
  16.  
  17. indent = 0;
  18.  
  19. }

完毕缩进后就该美化高亮显示代码了,这里要用到几个css规则。以下能够看到,对切分单元进行高亮显示的时候这里用正则进行推断,假设匹配到大括号标记为对象class、中括号标记为数组class、属性名称、属性值。一次对这些进行css规则加入,加入完毕之后拼接起来就能够了。

  1. .ObjectBrace{color:#00AA00;font-weight:bold;}
  2.  
  3. .ArrayBrace{color:#0033FF;font-weight:bold;}
  4.  
  5. .PropertyName{color:#CC0000;font-weight:bold;}
  6.  
  7. .String{color:#007777;}
  8.  
  9. .Number{color:#AA00AA;}
  10.  
  11. .Comma{color:#000000;font-weight:bold;}
  1. //加入代码高亮
  2.  
  3. node = node.replace(/([\{\}])/g,"<span class='ObjectBrace'>$1</span>");
  4.  
  5. node = node.replace(/([\[\]])/g,"<span class='ArrayBrace'>$1</span>");
  6.  
  7. node = node.replace(/(\".*\")(\:)(.*)(\,)?
  8.  
  9. /g,"<span class='PropertyName'>$1</span>$2$3$4");
  10.  
  11. node = node.replace(/\"([^"]*)\"(\,)?$/g,"<span class='String'>\"$1\"</span><span class='Comma'>$2</span>");
  12.  
  13. node = node.replace(/(-?
  14.  
  15. \d+)(\,)?$/g,"<span class='Number'>$1</span><span class='Comma'>$2</span>");

最后我们看看完整的方法代码(这里我使用了jquery类库)。以及測试地址:



要对jsonstr进行美化,这样就能够了APP.format(jsonstr),直接输出至<pre></pre>标签中就能够看到效果。



以下是一个測试地址,http://iforever.sinaapp.com/ 能够进去试一下。看看完整的源码

  1. <script>
  2.  
  3. var APP=function(){
  4.  
  5. var format=function(json){
  6.  
  7. var reg=null,
  8.  
  9. result='';
  10.  
  11. pad=0,
  12.  
  13. PADDING=' ';
  14.  
  15. if (typeof json !== 'string') {
  16.  
  17. json = JSON.stringify(json);
  18.  
  19. } else {
  20.  
  21. json = JSON.parse(json);
  22.  
  23. json = JSON.stringify(json);
  24.  
  25. }
  26.  
  27. // 在大括号前后加入换行
  28.  
  29. reg = /([\{\}])/g;
  30.  
  31. json = json.replace(reg, '\r\n$1\r\n');
  32.  
  33. // 中括号前后加入换行
  34.  
  35. reg = /([\[\]])/g;
  36.  
  37. json = json.replace(reg, '\r\n$1\r\n');
  38.  
  39. // 逗号后面加入换行
  40.  
  41. reg = /(\,)/g;
  42.  
  43. json = json.replace(reg, '$1\r\n');
  44.  
  45. // 去除多余的换行
  46.  
  47. reg = /(\r\n\r\n)/g;
  48.  
  49. json = json.replace(reg, '\r\n');
  50.  
  51. // 逗号前面的换行去掉
  52.  
  53. reg = /\r\n\,/g;
  54.  
  55. json = json.replace(reg, ',');
  56.  
  57. //冒号前面缩进
  58.  
  59. reg = /\:/g;
  60.  
  61. json = json.replace(reg, ': ');
  62.  
  63. //对json依照换行进行切分然后处理每个小块
  64.  
  65. $.each(json.split('\r\n'), function(index, node) {
  66.  
  67. var i = 0,
  68.  
  69. indent = 0,
  70.  
  71. padding = '';
  72.  
  73. //这里遇到{、[时缩进等级加1,遇到}、]时缩进等级减1,没遇到时缩进等级不变
  74.  
  75. if (node.match(/\{$/) || node.match(/\[$/)) {
  76.  
  77. indent = 1;
  78.  
  79. } else if (node.match(/\}/) || node.match(/\]/)) {
  80.  
  81. if (pad !== 0) {
  82.  
  83. pad -= 1;
  84.  
  85. }
  86.  
  87. } else {
  88.  
  89. indent = 0;
  90.  
  91. }
  92.  
  93. //padding保存实际的缩进
  94.  
  95. for (i = 0; i < pad; i++) {
  96.  
  97. padding += PADDING;
  98.  
  99. }
  100.  
  101. //加入代码高亮
  102.  
  103. node = node.replace(/([\{\}])/g,"<span class='ObjectBrace'>$1</span>");
  104.  
  105. node = node.replace(/([\[\]])/g,"<span class='ArrayBrace'>$1</span>");
  106.  
  107. node = node.replace(/(\".*\")(\:)(.*)(\,)?/g,"<span class='PropertyName'>$1</span>$2$3$4");
  108.  
  109. node = node.replace(/\"([^"]*)\"(\,)?$/g,"<span class='String'>\"$1\"</span><span class='Comma'>$2</span>");
  110.  
  111. node = node.replace(/(-?\d+)(\,)?$/g,"<span class='Number'>$1</span><span class='Comma'>$2</span>");
  112.  
  113. result += padding + node + '<br>';
  114.  
  115. pad += indent;
  116.  
  117. });
  118.  
  119. return result;
  120.  
  121. };
  122.  
  123. return {
  124.  
  125. "format":format,
  126.  
  127. };
  128.  
  129. }();
  130.  
  131. </script>

怎么样,json字符串是不是美观了非常多呢,超级有用吧。这么好的东东。当然不能独享,这里推荐给小伙伴们。

參考来源: 

使用正則表達式的格式化与高亮显示json字符串

http://www.lai18.com/content/351722.html

延伸阅读

《JavaScript正則表達式》系列技术文章整理收藏

1JavaScript正則表達式中的ignoreCase属性使用具体解释

2具体解释JavaScript正則表達式中的global属性的使用

3简述JavaScript的正則表達式中test()方法的使用

4在JavaScript的正則表達式中使用exec()方法

5JavaScript正則表達式之multiline属性的应用

6简述JavaScript中正則表達式的用法

7jQuery获取上传文件的名称的正則表達式

8【JavaScript】利用正則表達式检查输入框输入的是否为网址

9Javascript 正則表達式实现为数字加入千位分隔符

10javascript中的正則表達式使用指南

11javascript使用正則表達式实现去掉空格之后的字符

12调试JavaScript中正則表達式中遇到的问题

13jquery使用正則表達式验证email地址的方法

14javascript正則表達式之search()使用方法实例

15javascript正則表達式使用replace()替换手机号的方法

16jQuery中用dom操作替代正則表達式

17javascript使用正則表達式检測IP地址

18使用正則表達式的格式化与高亮显示json字符串

19Js 正則表達式知识汇总

20实例分析js和C#中使用正則表達式匹配a标签

21正則表達式在JavaScript应用

22正則表達式在javascript中的几个实例

23使用 js+正則表達式为关键词加入链接

24用正則表達式和javascript对表单进行全面验证

25javascript正則表達式检验

26javascript学习笔记(八)正則表達式

27JS应用正則表達式转换大写和小写演示样例

28javascript正則表達式參数/g与/i及/gi的使用指南

29JavaScript利用正則表達式去除日期中的“-”

30删除javascript中凝视语句的正則表達式

31JavaScript利用正則表達式去除日期中的-

32node.js正則表達式获取网页中全部链接的代码实例

33javascript经常使用的正則表達式实例

34JS使用replace()方法和正則表達式进行字符串的搜索与替换实例

35JavaScript中的正則表達式简明总结

36JavaScript表单通过正則表達式验证电话号码

37JavaScript通过正則表達式实现表单验证电话号码

38js动态拼接正則表達式的两种方法

39通过正則表達式实现表单验证是否为中文

40js正則表達式中test,exec,match方法的差别说明

41JS正則表達式验证数字代码

42利用js正則表達式验证手机号,email地址,邮政编码

43js验证电话号码与手机支持+86的正則表達式

44JavaScript中的正則表達式

45正則表達式中特殊符号及正則表達式的几种方法总结(replace,test,search)

46经常使用的JavaScript验证正則表達式汇总

47用正則表達式替换图片地址img标签

48javascipt匹配单行和多行凝视的正則表達式

49js用正則表達式来验证表单(比較齐全的资源)

50JS正則表達式获取分组内容的方法具体解释

51JS正則表達式大全(整理具体且有用)

52js将字符串转成正則表達式的实现方法

53JS经常使用正則表達式总结

54js编写trim()函数及正則表達式的运用

55jQuery中校验时间格式的正則表達式小结

56JQuery数字类型验证正則表達式

57jQuery经常使用的正則表達式

58jquery macth正則表達式实例

59jquery经常使用见的正則表達式

60Jquery Validate 正則表達式有用验证代码大全

61js正則表達式的使用具体解释

62怎样使用Javascript正則表達式来格式化XML内容

6330分钟就入门的正則表達式基础教程

64正則表達式搭配js轻松处理json文本方便而老古

65js replace正則表達式应用案例解说

66有用的JS正則表達式(手机号码/IP正则/邮编正则/电话等)

67javascript 正則表達式相关应介绍

68JavaScript高级程序设计(第3版)学习笔记12 js正則表達式

69Java 正則表達式学习总结和一些小样例

70js限制文本框仅仅能输入数字(正則表達式)

71js中推断数字\字母\中文的正則表達式 (实例)

72javascript学习笔记(十一) 正則表達式介绍

73js正則表達式

74获取server传来的数据 用JS去空格的正則表達式

75javascript 进阶篇1 正則表達式,cookie管理。userData

76jQuery源代码分析-02正則表達式 RegExp 经常使用正則表達式

77JavaScript正則表達式的浏览器的差异

78经常使用的JavaScript正則表達式

79jquery里的正則表達式说明

80PHP匹配连续的数字或字母的正則表達式

81Javascript中正則表達式的全局匹配模式分析

82javascript学习笔记(五)正則表達式

83正则总结:JavaScript中的正則表達式

84js 替换功能函数,用正則表達式解决。js的所有替换

85javascript正則表達式中參数g(全局)的作用

86js各种验证文本框输入格式(正則表達式)

87javascript 正則表達式(一)

88匹配随意字符的正則表達式写法

89javascript 正則表達式触发函数进行高级替换

90JavaScript 学习笔记(十四) 正則表達式

91javascript下利用数组缓存正則表達式的实现方法

92Mootools 1.2教程 正則表達式

93javascript 获取链接文件地址中第一个斜线内的正則表達式

94用正則表達式 动态创建/添加css style script 兼容IE firefox

95trim原型函数看js正則表達式的性能

96正則表達式推断是否存在中文和全角字符和推断包括中文字符串长度

97javascript replace方法与正則表達式

98JS的replace方法与正則表達式结合应用解说

99论坛转贴工具中用到的正則表達式学习正则的好样例

使用正則表達式的格式化与高亮显示json字符串的更多相关文章

  1. JavaScript正則表達式知识汇总

    Js 正則表達式知识汇总 正則表達式: 1.什么是RegExp?RegExp是正則表達式的缩写.RegExp 对象用于规定在文本中检索的内容. 2.定义RegExp:var +变量名=new RegE ...

  2. Python正則表達式:怎样使用正則表達式

    正則表達式(简称RE)本质上能够看作一个小的.高度专业化的编程语言,在Python中能够通过re模块使用它.使用正則表達式,你须要为想要匹配的字符串集合指定一套规则,字符串集合能够包括英文句子.e-m ...

  3. python之路-------字符串与正則表達式

    1.1.#####去掉字符串中的转义符string.strip() print "hello\tworld\n" >>> word="\thello w ...

  4. 深入浅出理解iOS经常使用的正則表達式—基础篇[Foundation]

    參考资料:cocoachina的zys475481075的文章 几个单词 Regular ['regjʊlə]adj. 定期的:有规律的 Expression[ɪk'spreʃ(ə)n; ek-] n ...

  5. JAVA学习第六十五课 — 正則表達式

    正則表達式:主要应用于操作字符串.通过一些特定的符号来体现 举例: QQ号的校验 6~9位.0不得开头.必须是数字 String类中有matches方法 matches(String regex) 告 ...

  6. javascript正則表達式

    定义一个正則表達式 能够用字面量 var regex = /xyz/; var regex = /xyz/i; 也能够用构造函数 var regex = new RegExp('xyz'); var ...

  7. VB.NET利用正則表達式巧妙限制字符输入

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/u010028869/article/details/37913867     在通常的程序设计中.对 ...

  8. Linux正則表達式-反复出现的字符

    星号(*)元字符表示它前面的正則表達式能够出现零次或多次.也就是说,假设它改动了单个字符.那么该字符能够在那里也能够不在那里,而且假设它在那里,那可能会不止出现一个.能够使用星号元字符匹配出如今引號中 ...

  9. 轻松学习之Linux教程六 正則表達式具体解释

    本系列文章由@超人爱因斯坦出品.转载请注明出处. 作者:超人爱因斯坦    个人站点:http://www.hpw123.net          文章链接:http://hpw123.net/a/L ...

随机推荐

  1. Java编程:常见问题汇总

    每天在写Java程序,其实里面有一些细节大家可能没怎么注意,这不,有人总结了一个我们编程中常见的问题.虽然一般没有什么大问题,但是最好别这样做. AD: 每天在写Java程序,其实里面有一些细节大家可 ...

  2. 217. Contains Duplicate@python

    Given an array of integers, find if the array contains any duplicates. Your function should return t ...

  3. 2018美赛准备之路——Matlab基础——命令行功能函数

    clc 清屏(只清除显示内容) clear  清除所有变量(运算结果) who  显示workspace的所有变量 whos  详细显示workspace的所有变量  help sin 显示sin函数 ...

  4. Mysql中max函数取得的值不是最大

    ①问题:遇到一个很有意思的问题,这里记录一下, 就是在使用max函数的时候发现取得的最大值其实不是最大值. 比如: 某一列中有10000000,和9999999, 其最大值应该是10000000但是查 ...

  5. linux(php环境) 安装ffmpeg

    实现上传视频获取视频的第一帧当做视频封面 1.安装ffmpeg ffmpeg的下载链接  https://ffmpeg.org/download.html 解压安装包 tar -jxvf ffmpeg ...

  6. JVM——内存管理和垃圾回收

    1.  何为GC 转载请注明出处:http://blog.csdn.net/seu_calvin/article/details/51892567 Java与C语言相比的一个优势是,可以通过自己的JV ...

  7. Couchbase V(管理任务)

    Couchbase V(管理任务) 多读写 在Couchbase2.1中支持硬盘多读些(Multi- Readers and Writers),一般双核4G服务默认3个thread 4核16G内存一个 ...

  8. Boolean.valueOf("true")的用法

    Boolean.valueOf(a);a为true时返回true不管大小写,a为其他值时都返回false:

  9. POJ1159:Palindrome【dp】

    题目大意:给出一个字符串,问至少添加多少个字符才能使它成为回文串? 思路:很明显的方程是:dp[i][j]=min{dp[i+1][j],dp[i][j-1],dp[i+1][j-1](str[i]= ...

  10. 2016 Multi-University Training Contest 6 solutions BY UESTC

    A Boring Question \[\sum_{0\leq k_{1},k_{2},\cdots k_{m}\leq n}\prod_{1\leq j< m}\binom{k_{j+1}}{ ...