js格式化json數據 + json著色 - 附源碼

来源:https://www.cnblogs.com/Sinhtml/archive/2018/01/23/8336930.html
-Advertisement-
Play Games

其實json格式化沒想象中的那麼複雜,難點就是json格式化的工作流程。 正好工作上需要,於是就搞了一套json格式化+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 

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文設計到常見對文檔的處理樣式,和塊,行標簽的特點。 沒用什麼重要內容,只是自己的一些知識點的回憶,對以前知識的一個梳理過程,望某懶蟲加油!!! ...
  • classList屬性的方法:add();remove();toggle(); 描述,在一些頁面我們需要使用兩個按鈕來回切換,如圖: 我們要使用到add()和remove()方法 html部分: <div class="login-title"> <a href="javascript:void(0 ...
  • 2017年npm上最熱門的項目之一——Pkg,可以直接將node.js項目打包成windows可以直接執行的exe文件(也支持FreeBSD、linux、macos、arm系統),並且無須修改你項目中的任何代碼。本文對該項目作了簡要說明與教程,並提供了一個簡單示例來說明其使用場景。 ...
  • CreateJS介紹請看CreateJS中文網或者官方網站 一.使用EaselJS 先到官網下載easeljs,也可以點這裡 1.得到easeljs-0.8.1.min.js後,新建一個HTML5文件並導入: 2.入口函數和創建canvas標簽: 3.創建舞臺: 二.使用EaselJS創建圖形和文字 ...
  • css代碼: html代碼: JS調用: ...
  • jquery的綠色拖動驗證功能 在網上看到了一個這樣的問題:那種像拖動滑塊匹配圖形的驗證方式是怎麼實現的?。 突然想到實現一個簡單綠色拖動驗證碼的功能,在網上搜了下,有一個用jquery實現的該功能代碼。 體驗地址:http://yanshi.sucaihuo.com/jquery/8/897/de ...
  • 最近在做的一個後臺管理系統,發現一個bug: 問題描述:如果其他列表項都用類為col-xs-12的div包裹,而引入UEditor的部分不用類為col-xs-12的div包裹,那麼其他列表項將無法顯示,UEditor編輯框也顯示不完全; 解決辦法:將引入UEditor的部分也用類為col-xs-12 ...
  • Vuex 是一個專為 Vue.js 應用程式開發的狀態管理模式。它採用集中式存儲管理應用的所有組件的狀態,並以相應的規則保證狀態以一種可預測的方式發生變化。 在 Vue 之後引入 vuex 會進行自動安裝: 可以通過 https://unpkg.com/[email protected] 這樣的方式指定特定的版本 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...