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

前端技术 2023/09/08 JavaScript

json字符串很有用,有时候一些后台接口返回的信息是字符串格式的,可读性很差,这个时候要是有个可以格式化并高亮显示json串的方法那就好多了,下面看看一个正则表达式完成的json字符串的格式化与高亮显示

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

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

本文地址:https://www.stayed.cn/item/22983

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。