正則表達(dá)式優(yōu)化JSON字符串的技巧
json字符串很有用,有時(shí)候一些后臺接口返回的信息是字符串格式的,可讀性很差,這個(gè)時(shí)候要是有個(gè)可以格式化并高亮顯示json串的方法那就好多了,下面看看一個(gè)正則表達(dá)式完成的json字符串的格式化與高亮顯示
首先是對輸入進(jìn)行轉(zhuǎn)換,如果是對象則轉(zhuǎn)化為規(guī)范的json字符串,不是對象時(shí),先將字符串轉(zhuǎn)化為對象(防止不規(guī)范的字符串),然后再次轉(zhuǎn)化為json串。其中json為輸入。
if (typeof json !== 'string') { json = JSON.stringify(json); } else { json = JSON.parse(json); json = JSON.stringify(json); }
等規(guī)范完數(shù)據(jù)之后對字符串進(jìn)行標(biāo)記,為了后面的切分、重新組合
這里有幾個(gè)地方要添加標(biāo)記,包括大括號、小括號的前后和逗號的后面都要添加標(biāo)記,我這里使用的是換行\(zhòng)r\n(這樣在命令行下測試時(shí)效果會比較好看)。
// 在大括號前后添加換行 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');
添加完成標(biāo)記之后就要做一些優(yōu)化處理,去掉多余的換行、去掉逗號前面的換行,這樣做是為了在切分是免得出現(xiàn)空串浪費(fèi)一次循環(huán)處理,最后在冒號后面添加空格,看起來更漂亮。
// 去除多余的換行 reg = /(\r\n\r\n)/g; json = json.replace(reg, '\r\n'); // 逗號前面的換行去掉 reg = /\r\n\,/g; json = json.replace(reg, ','); //冒號前面縮進(jìn) reg = /\:/g; json = json.replace(reg, ': ');
接下來就是對這個(gè)初步處理過的串進(jìn)行進(jìn)一步處理了,我會在function(index, node) {}函數(shù)中添加邏輯,對每一個(gè)切分單元進(jìn)行處理,包括縮進(jìn)和美化格式。
$.each(json.split('\r\n'), function(index, node) {});
首先說下縮進(jìn),縮進(jìn)的方法很簡單,遇到{、[符號時(shí)縮進(jìn)增加1,遇到}、]符號時(shí)縮進(jìn)減少1,否則縮進(jìn)量不變。
//這里遇到{、[時(shí)縮進(jìn)等級加1,遇到}、]時(shí)縮進(jìn)等級減1,沒遇到時(shí)縮進(jìn)等級不變 if (node.match(/\{$/) || node.match(/\[$/)) { indent = 1; } else if (node.match(/\}/) || node.match(/\]/)) { if (pad !== 0) { pad -= 1; } } else { indent = 0; }
完成縮進(jìn)后就該美化高亮顯示代碼了,這里要用到幾個(gè)css規(guī)則,下面可以看到,對切分單元進(jìn)行高亮顯示的時(shí)候這里用正則進(jìn)行判斷,如果匹配到大括號標(biāo)記為對象class、中括號標(biāo)記為數(shù)組class、屬性名稱、屬性值,一次對這些進(jìn)行css規(guī)則添加,添加完成之后拼接起來就可以了。
.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進(jìn)行美化,這樣就可以了APP.format(jsonstr),直接輸出至<pre></pre>標(biāo)簽中就可以看到效果,
下面是一個(gè)測試地址,http://iforever.sinaapp.com/ 可以進(jìn)去試一下,看看完整的源代碼
<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, ','); //冒號前面縮進(jìn) reg = /\:/g; json = json.replace(reg, ': '); //對json按照換行進(jìn)行切分然后處理每一個(gè)小塊 $.each(json.split('\r\n'), function(index, node) { var i = 0, indent = 0, padding = ''; //這里遇到{、[時(shí)縮進(jìn)等級加1,遇到}、]時(shí)縮進(jìn)等級減1,沒遇到時(shí)縮進(jìn)等級不變 if (node.match(/\{$/) || node.match(/\[$/)) { indent = 1; } else if (node.match(/\}/) || node.match(/\]/)) { if (pad !== 0) { pad -= 1; } } else { indent = 0; } //padding保存實(shí)際的縮進(jìn) 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>
PS:正則表達(dá)式替換json字符串的某一項(xiàng)的數(shù)字值
aa=aa.replaceAll("\"ccfsID\":\"[0-9]*\"", "\"ccfsID\":\""+id1+"\"");
aa為json字符串,如:
{"items":[{"dishprice":30,"ccfsID":"","order.item.id":1,"zuofaid":"","zuofajiajia":0,"isTaoCan":false,"num":1,"price":30,"name":"","ID":"00000001","lsdishID":"","zuofaname":"","tzs":"","addTime":"2013-05-14"}],"deskId":"00000008"}
相關(guān)文章
微信小程序基于數(shù)據(jù)庫時(shí)間實(shí)現(xiàn)商品倒計(jì)時(shí)功能(可重用代碼)
這篇文章主要介紹了微信小程序基于數(shù)據(jù)庫時(shí)間實(shí)現(xiàn)商品倒計(jì)時(shí)功能(可重用代碼),代碼很完整,拿來就可以使用,現(xiàn)在我把完整的代碼分享給大家,需要的朋友可以參考下2022-07-07基于MVC方式實(shí)現(xiàn)三級聯(lián)動(JavaScript)
這篇文章主要為大家詳細(xì)介紹了基于MVC方式實(shí)現(xiàn)三級聯(lián)動的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01PHP中如何unicode編碼,在JavaScript中h如何解碼
PHP中如何unicode編碼,在JavaScript中如何解碼?js中h這樣的,怎么轉(zhuǎn)碼?2023-07-07JS從數(shù)組中隨機(jī)獲取一個(gè)值的常用寫法
這篇文章主要介紹了JS從數(shù)組中隨機(jī)獲取一個(gè)值的常用寫法,需要的朋友可以參考下2023-07-07用js控件div的滾動條,讓它在內(nèi)容更新時(shí)自動滾到底部的實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄胘s控件div的滾動條,讓它在內(nèi)容更新時(shí)自動滾到底部的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-10-10純 JS 實(shí)現(xiàn)放大縮小拖拽功能(完整代碼)
這篇文章主要介紹了純js實(shí)現(xiàn)放大縮小拖拽功能,文中給大家提到了在開發(fā)過程中遇到的一些問題及解決方法,需要的朋友可以參考下2019-11-11