JSON

正则表达式优化JSON字符串的技巧

字号+ 作者:H5之家 来源:H5之家 2016-01-18 09:06 我要评论( )

JavaScript,正则表达式优化JSON字符串的技巧,UDN开发者论坛,专注企业互联网开发的IT技术社区

  json字符串很有用,有时候一些后台接口返回的信息是字符串格式的,可读性很差,这个时候要是有个可以格式化并高亮显示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) {});

    复制代码


      首先说下缩进,缩进的方法很简单,遇到{、[符号时缩进增加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>$1</span>");
  • node = node.replace(/([\[\]])/g,"<span>$1</span>");
  • node = node.replace(/(\".*\")(\:)(.*)(\,)?/g,"<span>$1</span>$2$3$4");
  • node = node.replace(/\"([^"]*)\"(\,)?$/g,"<span>\"$1\"</span><span>$2</span>");
  • node = node.replace(/(-?\d+)(\,)?$/g,"<span>$1</span><span>$2</span>");

    复制代码


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

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

  • <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;
  • jso 6ddd n = 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>$1</span>");
  • node = node.replace(/([\[\]])/g,"<span>$1</span>");
  • node = node.replace(/(\".*\")(\:)(.*)(\,)?/g,"<span>$1</span>$2$3$4");
  • node = node.replace(/\"([^"]*)\"(\,)?$/g,"<span>\"$1\"</span><span>$2</span>");
  • node = node.replace(/(-?\d+)(\,)?$/g,"<span>$1</span><span>$2</span>");
  • result += padding + node + '<br>';
  • pad += indent;
  • });
  • return result;
  • };
  • return {
  • "format":format,
  • };
  • }();
  • </script>

    复制代码


      PS:正则表达式替换json字符串的某一项的数字值

  • aa=aa.replaceAll("\"ccfsID\":\"[0-9]*\"", "\"ccfsID\":\""+id1+"\"");

    复制代码


      aa为json字符串,如:

     

  • 1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

    相关文章
    • JavaScript转换与解析JSON方法实例详解第1/2页

      JavaScript转换与解析JSON方法实例详解第1/2页

      2016-02-10 21:25

    • 未来编程的9大猜想:JavaScript不必亲自编写

      未来编程的9大猜想:JavaScript不必亲自编写

      2016-01-30 13:01

    • Objective-C与JavaScript交互的那些事

      Objective-C与JavaScript交互的那些事

      2016-01-30 13:00

    • 实用的javascript小技巧

      实用的javascript小技巧

      2016-01-25 19:05

    网友点评