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

 更新时间:2014年12月03日 08:54:31   投稿:hebedich  
这篇文章主要介绍了使用正则表达式的格式化与高亮显示json字符串的方法,非常的简单实用,需要的朋友可以参考下

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 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字符串是不是美观了很多呢,超级实用吧,这么好的东东,当然不能独享,这里推荐给小伙伴们。

相关文章

  • js图数据结构处理 迪杰斯特拉算法代码实例

    js图数据结构处理 迪杰斯特拉算法代码实例

    这篇文章主要介绍了js图数据结构处理 迪杰斯特拉算法代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • java必学必会之static关键字

    java必学必会之static关键字

    java必学必会之static关键字,static关键字是很多朋友在编写代码和阅读代码时碰到的比较难以理解的一个关键字,下面结合大家一起学习static关键字
    2015-12-12
  • JS实现Enter键跳转及控件获得焦点

    JS实现Enter键跳转及控件获得焦点

    想让Enter键跳转的同时让控件获得焦点,具体实现js代码如下,感兴趣的朋友可以参考下,希望对大家有所帮助
    2013-08-08
  • JavaScript中常见的几种继承方式

    JavaScript中常见的几种继承方式

    这篇文章主要介绍了JavaScript中常见的几种继承方式,继承可以访问父类原型上的方法或属性,实现了方法复用,但是创建子类实例时,不能传父类的参数,子类实例共享了父类构造函数的属性值
    2022-06-06
  • layui异步加载table表中某一列数据的例子

    layui异步加载table表中某一列数据的例子

    今天小编就为大家分享一篇layui异步加载table表中某一列数据的例子,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-09-09
  • js实现省级联动(数据结构优化)

    js实现省级联动(数据结构优化)

    这篇文章主要为大家详细介绍了js实现省级联动,数据结构优化,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-07-07
  • 去除element-ui中Dialog对话框遮罩层方法详解

    去除element-ui中Dialog对话框遮罩层方法详解

    这篇文章主要为大家介绍了去除element-ui中Dialog对话框遮罩层方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • 百度UEditor编辑器如何关闭抓取远程图片功能

    百度UEditor编辑器如何关闭抓取远程图片功能

    这篇文章主要介绍了百度UEditor编辑器如何关闭抓取远程图片功能,需要的朋友可以参考下
    2015-03-03
  • 微信小程序实现无缝滚动

    微信小程序实现无缝滚动

    这篇文章主要为大家详细介绍了微信小程序实现无缝滚动,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-03-03
  • javascript 无限联动菜单效果代码

    javascript 无限联动菜单效果代码

    javascript 无限联动菜单效果代码,需要的朋友可以参考下。
    2010-04-04

最新评论