js格式化json数据 + json着色 - 附源码

  其实json格式化没想象中的那么复杂,难点就是json格式化的工作流程。

正好工作上需要,于是就搞了一套json格式化+json着色的方法,原生的方法,可以直接使用。json数据格式化前后对比图,如下:

下面是源码,可以根据个人需求适当修改:

  1 <!DOCTYPE html>
  2 <html lang="en">
  3 <head>
  4     <meta charset="UTF-8">
  5     <title>js格式化json+json着色的方法</title>
  6     <script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
  7     <style>
  8     body {font-size:14px;font-family:consolas;}
  9     pre {font-family:‘consolas‘;}
 10     .Canvas {
 11         font:14px/18px ‘consolas‘;
 12         background-color: #ECECEC;
 13         color: #000000;
 14         border: solid 1px #CECECE;
 15     }
 16     .ObjectBrace {
 17         color: #00AA00;
 18         font-weight: bold;
 19     }
 20     .ArrayBrace {
 21         color: #0033FF;
 22         font-weight: bold;
 23     }
 24     .PropertyName {
 25         color: #CC0000;
 26         font-weight: bold;
 27     }
 28     .String {
 29         color: #007777;
 30     }
 31     .Number {
 32         color: #AA00AA;
 33     }
 34     .Boolean {
 35         color: #0000FF;
 36     }
 37     .Function {
 38         color: #AA6633;
 39         text-decoration: italic;
 40     }
 41     .Null {
 42         color: #0000FF;
 43     }
 44     .Comma {
 45         color: #000000;
 46         font-weight: bold;
 47     }
 48     PRE.CodeContainer {
 49         margin-top: 0px;
 50         margin-bottom: 0px;
 51     }
 52 </style>
 53
 54 </head>
 55 <body>
 56 <!--格式化后的json写入的位置-->
 57 <div id="writePlace"></div><br>
 58 <button onclick="Process()">着色</button>
 59 <div id="Canvas"></div>
 60 <script>
 61 //格式化代码函数,已经用原生方式写好了不需要改动,直接引用就好
 62 var formatJson = function (json, options) {
 63     var reg = null,
 64             formatted = ‘‘,
 65             pad = 0,
 66             PADDING = ‘    ‘;
 67     options = options || {};
 68     options.newlineAfterColonIfBeforeBraceOrBracket = (options.newlineAfterColonIfBeforeBraceOrBracket === true) ? true : false;
 69     options.spaceAfterColon = (options.spaceAfterColon === false) ? false : true;
 70     if (typeof json !== ‘string‘) {
 71         json = JSON.stringify(json);
 72     } else {
 73         json = JSON.parse(json);
 74         json = JSON.stringify(json);
 75     }
 76     reg = /([\{\}])/g;
 77     json = json.replace(reg, ‘\r\n$1\r\n‘);
 78     reg = /([\[\]])/g;
 79     json = json.replace(reg, ‘\r\n$1\r\n‘);
 80     reg = /(\,)/g;
 81     json = json.replace(reg, ‘$1\r\n‘);
 82     reg = /(\r\n\r\n)/g;
 83     json = json.replace(reg, ‘\r\n‘);
 84     reg = /\r\n\,/g;
 85     json = json.replace(reg, ‘,‘);
 86     if (!options.newlineAfterColonIfBeforeBraceOrBracket) {
 87         reg = /\:\r\n\{/g;
 88         json = json.replace(reg, ‘:{‘);
 89         reg = /\:\r\n\[/g;
 90         json = json.replace(reg, ‘:[‘);
 91     }
 92     if (options.spaceAfterColon) {
 93         reg = /\:/g;
 94         json = json.replace(reg, ‘:‘);
 95     }
 96     (json.split(‘\r\n‘)).forEach(function (node, index) {
 97         //console.log(node);
 98         var i = 0,
 99             indent = 0,
100             padding = ‘‘;
101
102         if (node.match(/\{$/) || node.match(/\[$/)) {
103             indent = 1;
104         } else if (node.match(/\}/) || node.match(/\]/)) {
105             if (pad !== 0) {
106                 pad -= 1;
107             }
108         } else {
109                 indent = 0;
110         }
111
112         for (i = 0; i < pad; i++) {
113             padding += PADDING;
114         }
115
116         formatted += padding + node + ‘\r\n‘;
117         pad += indent;
118     });
119     return formatted;
120 };
121 //引用示例部分
122 //(1)创建json格式或者从后台拿到对应的json格式
123 //var originalJson = {"name": "binginsist", "sex": "男", "age": "25"};
124 //下面用一个真实的json数据做测试
125 var originalJson = {
126     "_errmsg":"ok",
127     "result":[
128     ],
129     "stat":"wechat",
130     "_token":"",
131     "weixinId":"900504",
132     "_errcode":"0",
133     "regionId":"00000000"
134 }
135
136 //(2)调用formatJson函数,将json格式进行格式化
137 var resultJson = formatJson(originalJson);
138 //(3)将格式化好后的json写入页面中
139 document.getElementById("writePlace").innerHTML = ‘<pre>‘ +resultJson + ‘<pre/>‘;
140
141
142 //着色
143 window.TAB = "    ";
144 function IsArray(obj) {
145   return obj &&
146       typeof obj === ‘object‘ &&  typeof obj.length === ‘number‘ && !(obj.propertyIsEnumerable(‘length‘));
147 }
148 function Process() {
149     var json = $(‘#writePlace‘).text();
150     console.log(json);
151     document.getElementById("Canvas").style.display = "block";
152     var html = "";
153     try {
154         if (json == "") {
155             json = ‘""‘;
156         }
157         var obj = eval("[" + json + "]");
158         html = ProcessObject(obj[0], 0, false, false, false);
159         document.getElementById("Canvas").innerHTML = "<PRE class=‘CodeContainer‘>" + html + "</PRE>";
160     } catch(e) {
161         alert("json语法错误,不能格式化。错误信息:\n" + e.message);
162         document.getElementById("Canvas").innerHTML = "";
163     }
164 }
165 function ProcessObject(obj, indent, addComma, isArray, isPropertyContent) {
166     var html = "";
167     var comma = (addComma) ? "<span class=‘Comma‘>,</span> ": "";
168     var type = typeof obj;
169     if (IsArray(obj)) {
170         if (obj.length == 0) {
171             html += GetRow(indent, "<span class=‘ArrayBrace‘>[ ]</span>" + comma, isPropertyContent);
172         } else {
173             html += GetRow(indent, "<span class=‘ArrayBrace‘>[</span>", isPropertyContent);
174             for (var i = 0; i < obj.length; i++) {
175                 html += ProcessObject(obj[i], indent + 1, i < (obj.length - 1), true, false);
176             }
177             html += GetRow(indent, "<span class=‘ArrayBrace‘>]</span>" + comma);
178         }
179     } else {
180         if (type == "object" && obj == null) {
181             html += FormatLiteral("null", "", comma, indent, isArray, "Null");
182         } else {
183             if (type == "object") {
184                 var numProps = 0;
185                 for (var prop in obj) {
186                     numProps++;
187                 }
188                 if (numProps == 0) {
189                     html += GetRow(indent, "<span class=‘ObjectBrace‘>{ }</span>" + comma, isPropertyContent)
190                 } else {
191                     html += GetRow(indent, "<span class=‘ObjectBrace‘>{</span>", isPropertyContent);
192                     var j = 0;
193                     for (var prop in obj) {
194                         html += GetRow(indent + 1, ‘<span class="PropertyName">"‘ + prop + ‘"</span>: ‘ + ProcessObject(obj[prop], indent + 1, ++j < numProps, false, true))
195                     }
196                     html += GetRow(indent, "<span class=‘ObjectBrace‘>}</span>" + comma);
197                 }
198             } else {
199                 if (type == "number") {
200                     html += FormatLiteral(obj, "", comma, indent, isArray, "Number");
201                 } else {
202                     if (type == "boolean") {
203                         html += FormatLiteral(obj, "", comma, indent, isArray, "Boolean");
204                     } else {
205                         if (type == "function") {
206                             obj = FormatFunction(indent, obj);
207                             html += FormatLiteral(obj, "", comma, indent, isArray, "Function");
208                         } else {
209                             if (type == "undefined") {
210                                 html += FormatLiteral("undefined", "", comma, indent, isArray, "Null");
211                             } else {
212                                 html += FormatLiteral(obj, ‘"‘, comma, indent, isArray, "String");
213                             }
214                         }
215                     }
216                 }
217             }
218         }
219     }
220     return html;
221 };
222
223 function FormatLiteral(literal, quote, comma, indent, isArray, style) {
224     if (typeof literal == "string") {
225         literal = literal.split("<").join("&lt;").split(">").join("&gt;");
226     }
227     var str = "<span class=‘" + style + "‘>" + quote + literal + quote + comma + "</span>";
228     if (isArray) {
229         str = GetRow(indent, str);
230     }
231     return str;
232 }
233 function FormatFunction(indent, obj) {
234     var tabs = "";
235     for (var i = 0; i < indent; i++) {
236         tabs += window.TAB;
237     }
238     var funcStrArray = obj.toString().split("\n");
239     var str = "";
240     for (var i = 0; i < funcStrArray.length; i++) {
241         str += ((i == 0) ? "": tabs) + funcStrArray[i] + "\n";
242     }
243     return str;
244 }
245 function GetRow(indent, data, isPropertyContent) {
246     var tabs = "";
247     for (var i = 0; i < indent && !isPropertyContent; i++) {
248         tabs += window.TAB;
249     }
250     if (data != null && data.length > 0 && data.charAt(data.length - 1) != "\n") {
251         data = data + "\n";
252     }
253     return tabs + data;
254 };
255 </script>
256 </body>
257 </html>

原文地址:https://www.cnblogs.com/Sinhtml/p/8336930.html

时间: 2024-10-12 16:19:19

js格式化json数据 + json着色 - 附源码的相关文章

js实现轮播图效果(附源码)--原生js的应用

1.js实现轮播图效果 <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <meta name="Author" content="奇客艺术"> <meta name="keyword" content="关键字"> <meta name=

原生JS实现贪吃蛇项目,附源码下载!

运行于谷歌浏览器.主要是利用了函数的封装思想,把每一个小功能分别封装在一个函数中,大大提高了代码的可扩展性!!提高了代码的可维护性!!!提高了代码的可阅读性!!!项目要求:1:有边界,碰到边界就game over.2:猎物没3秒增加一个,而且位置随机产生.3:吃一个猎物自身就增加一个元素.4:按上下左右控制移动方向,按空格决定暂停和前进. 实现思路:主要是一开始就把实现的功能封装在了一个先函数中去了,所以后续的功能增加就比较容易了.1:先画出了边界,就是实现了设置边界的函数.2:实现判断按键功能

Android客户端与服务端(jsp)之间json的传输与解析【附效果图附源码】

最近有个项目需要用到json的传输,之前不是太了解,在网上找了些相关资料,写了一个小小的demo,可以实现基本功能:android客户端发送json到服务端,服务端使用jsp接收,解析后以json的形式返回给客户端,客户端接收打印,先看看运行的效果截图,源码会在文章的末尾给出. 1.服务端:接收到json后解析打印,然后发送json到客户端 2.客户端,收到服务端返回的json后打印 简单的介绍下源码: 服务端使用json.jsp来接收解析客户端传过来的json,json的解析需要使用lib目录

极限挑战—C#100万条数据导入SQL SERVER数据库仅用4秒 (附源码)

原文:极限挑战-C#100万条数据导入SQL SERVER数据库仅用4秒 (附源码) 实际工作中有时候需要把大量数据导入数据库,然后用于各种程序计算,本实验将使用5中方法完成这个过程,并详细记录各种方法所耗费的时间. 本实验中所用到工具为VS2008和SQL SERVER 2000.SQL SERVER 2008,分别使用5中方法将100万条数据导入SQL 2000与SQL 2008中,实验环境是DELL 2850双2.0GCPU,2G内存的服务器.感兴趣的朋友可以下载源代码自己验证一下所用时间

javaweb异常提示信息统一处理(使用springmvc,附源码)

一.前言 后台出现异常如何友好而又高效地回显到前端呢?直接将一堆的错误信息抛给用户界面,显然不合适. 先不考虑代码实现,我们希望是这样的: (1)如果是页面跳转的请求,出现异常了,我们希望跳转到一个异常显示页面,如下: 当然,这里的界面不够美观,但是理论是这样的. (2)如果是ajax请求,那么我们,希望后台将合理的错误显示返回到ajax的回调函数里面,如下: $.ajax({ type: "post", url: "<%=request.getContextPath(

微信公众平台开发教程(四) 实例入门:机器人(附源码)

微信公众平台开发教程(四) 实例入门:机器人(附源码) 上一篇文章,写了基本框架,可能很多人会觉得晕头转向,这里提供一个简单的例子来予以说明,希望能帮你解开谜团. 一.功能介绍 通过微信公众平台实现在线客服机器人功能.主要的功能包括:简单对话.查询天气等服务. 这里只是提供比较简单的功能,重在通过此实例来说明公众平台的具体研发过程.只是一个简单DEMO,如果需要的话可以在此基础上进行扩展. 当然后续我们还会推出比较复杂的应用实例. 二.具体实现 1.提供访问接口 这里不再赘述,参照上一章,微信公

从零开始编写自己的C#框架(6)——SubSonic3.0插件介绍(附源码)

原文:从零开始编写自己的C#框架(6)--SubSonic3.0插件介绍(附源码) 前面几章主要是概念性的东西为主,向初学者们介绍项目开始前的一些知识与内容,从本章开始将会进入实操阶段,希望跟着本系统学习的朋友认真按说明做好每一步操作(对于代码最好是直接照着文档内容在你的IDE中打一次出来,而不是使用复制粘贴),这样对你理解后面的章节会有较好的帮助,如果你对我这种书写方式有什么建议或支持,也希望在评论中留言,谢谢你的支持. SubSonic3.0简介 SubSonic是Rob Conery用c#

C# winform 实现微信二维码登录、第三方登录(已实现、附源码)

原文:C# winform 实现微信二维码登录.第三方登录(已实现.附源码) 前言 应上级要求,在项目登录的时候实现第三方登录.很荣幸我接到了这个任务,但是我之前完全都没接触到.开发周期是三天,对于我们这种小白完全是从零开始.最后成功的实现这个功能固然重要,但是这个探索的过程才值得回味.光需要代码可以直接下载源码,我们重要说下实现过程和步骤,自己也巩固和记录一下! 实现步骤 1. 我实现的是微信扫码登录,当然要知道微信给的接口,可以在https://open.weixin.qq.com/ 这里申

HTML5网页录音和压缩,边猜边做..(附源码)

宣传一下自己的qq群:5946699 (暗号:C#交流) 欢迎喜欢C#,热爱C#,正在学习C#,准备学习C#的朋友来这里互相学习交流,共同进步 群刚建,人不多,但是都是真正热爱C#的 我也是热爱C#的 希望大家可以一起交流,共同进步 最近公司需要用到web录音的功能 本人接手了这个任务 在网上找了一些资料 http://www.jsjtt.com/webkaifa/html5/2013-08-28/34.html http://javascript.ruanyifeng.com/bom/webr