源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2020-12-16 07:05 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:使用正则表达式的格式化与高亮显示json字符串
json字符串很有用,有时候一些后台接口返回的信息是字符串格式的,可读性很差,这个时候要是有个可以格式化并高亮显示json串的方法那就好多了,下面看看一个正则表达式完成的json字符串的格式化与高亮显示 首先是对输入进行转换,如果是对象则转化为规范的json字符串,不是对象时,先将字符串转化为对象(防止不规范的字符串),然后再次转化为json串。其中json为输入。
[url=http://iforever.sinaapp.com/]http://iforever.sinaapp.com/[/url] 可以进去试一下,看看完整的源代码
[u]复制代码[/u] 代码如下:
<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字符串是不是美观了很多呢,超级实用吧,这么好的东东,当然不能独享,这里推荐给小伙伴们。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部