亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Regex > 正文

正則表達式優化JSON字符串的技巧

2020-03-16 21:01:20
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了正則表達式優化JSON字符串的技巧的相關資料,需要的朋友可以參考下
 

json字符串很有用,有時候一些后臺接口返回的信息是字符串格式的,可讀性很差,這個時候要是有個可以格式化并高亮顯示json串的方法那就好多了,下面看看一個正則表達式完成的json字符串的格式化與高亮顯示

首先是對輸入進行轉換,如果是對象則轉化為規范的json字符串,不是對象時,先將字符串轉化為對象(防止不規范的字符串),然后再次轉化為json串。其中json為輸入。

if (typeof json !== 'string') {json = JSON.stringify(json);} else {json = JSON.parse(json);json = JSON.stringify(json);} 

等規范完數據之后對字符串進行標記,為了后面的切分、重新組合

這里有幾個地方要添加標記,包括大括號、小括號的前后和逗號的后面都要添加標記,我這里使用的是換行/r/n(這樣在命令行下測試時效果會比較好看)。

// 在大括號前后添加換行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, ': '); 

接下來就是對這個初步處理過的串進行進一步處理了,我會在function(index, node) {}函數中添加邏輯,對每一個切分單元進行處理,包括縮進和美化格式。

$.each(json.split('/r/n'), function(index, node) {}); 

首先說下縮進,縮進的方法很簡單,遇到{、[符號時縮進增加1,遇到}、]符號時縮進減少1,否則縮進量不變。

//這里遇到{、[時縮進等級加1,遇到}、]時縮進等級減1,沒遇到時縮進等級不變if (node.match(//{$/) || node.match(//[$/)) {indent = 1;} else if (node.match(//}/) || node.match(//]/)) {if (pad !== 0) {pad -= 1;}} else {indent = 0;} 

完成縮進后就該美化高亮顯示代碼了,這里要用到幾個css規則,下面可以看到,對切分單元進行高亮顯示的時候這里用正則進行判斷,如果匹配到大括號標記為對象class、中括號標記為數組class、屬性名稱、屬性值,一次對這些進行css規則添加,添加完成之后拼接起來就可以了。

.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進行美化,這樣就可以了APP.format(jsonstr),直接輸出至<pre></pre>標簽中就可以看到效果,

下面是一個測試地址,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>

PS:正則表達式替換json字符串的某一項的數字值

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"}
 


注:相關教程知識閱讀請移步到正則表達式頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品专区一| 日本精品视频网站| 日韩精品亚洲元码| 69影院欧美专区视频| 亚洲国产精品久久久久| 日韩在线精品视频| 日韩精品高清视频| 欧美野外猛男的大粗鳮| 国产精品女人久久久久久| 久久精品一本久久99精品| 精品国产91久久久久久老师| 久久精品亚洲热| 2021国产精品视频| 久久精品视频中文字幕| 亚洲人成伊人成综合网久久久| 久久综合久久八八| 欧美日韩亚洲91| 亚洲精品国产品国语在线| 日韩久久精品电影| 91热福利电影| 欧美午夜无遮挡| 欧美亚洲国产视频| 成人黄色片在线| 色偷偷偷亚洲综合网另类| 亚洲成人av在线播放| 欧美日韩国产999| 亚洲一区二区三区在线免费观看| 欧美视频在线观看 亚洲欧| 亚洲国产精品yw在线观看| 亚洲国产成人在线视频| 91成人在线观看国产| 久久精品视频导航| 久久精品国产2020观看福利| 中文字幕av一区二区三区谷原希美| 亚洲韩国日本中文字幕| 亚洲精品v欧美精品v日韩精品| 欧美亚洲激情在线| 日本午夜人人精品| 亚洲国产又黄又爽女人高潮的| 欧美日韩成人在线播放| 日韩精品在线看| 欧美日韩国产一区二区| 91精品视频一区| 亚洲2020天天堂在线观看| 自拍亚洲一区欧美另类| 中文字幕在线看视频国产欧美| 视频一区视频二区国产精品| 久久精品国产一区| 日韩精品在线影院| 北条麻妃一区二区在线观看| 久久伊人91精品综合网站| 91在线观看免费高清| 日韩精品免费在线| 国产精品一区二区在线| 久久久久久成人精品| 国产主播在线一区| 精品国产乱码久久久久久婷婷| 亚洲综合自拍一区| 欧美午夜片在线免费观看| 在线观看日韩专区| 91精品国产亚洲| 日本在线观看天堂男亚洲| www国产精品视频| 最新国产成人av网站网址麻豆| 日韩一级裸体免费视频| 国产日韩换脸av一区在线观看| 国产精品日韩欧美综合| 久久久久国产精品免费网站| 欧美日韩国产精品一区| 欧美另类69精品久久久久9999| 日韩在线播放视频| 亚洲精品视频在线播放| 国产一区红桃视频| 精品国产一区二区三区久久| 亚洲一区亚洲二区亚洲三区| 国产精品嫩草视频| 日韩欧美在线字幕| 亚洲免费成人av电影| 性欧美在线看片a免费观看| 日韩在线视频网站| 国产精品视频中文字幕91| 欧美日韩加勒比精品一区| 国产91成人在在线播放| 久久精品国产成人精品| 亚洲国产成人在线播放| 欧美一级高清免费| 久久久91精品国产一区不卡| 欧美色欧美亚洲高清在线视频| 亚洲精品在线观看www| 成人黄色短视频在线观看| 久久在线免费视频| 另类视频在线观看| 欧美午夜女人视频在线| 亚洲色图第三页| 欧美性猛交xxxxx水多| 97在线视频一区| 国产成人一区二区三区小说| 91欧美视频网站| 日韩在线视频观看| 亚洲欧美一区二区三区四区| 久久久久久网址| 国产精品久久久久久久久久| 欧美高清理论片| 精品日韩美女的视频高清| 国产精品日日摸夜夜添夜夜av| 精品人伦一区二区三区蜜桃网站| 色老头一区二区三区| 国产盗摄xxxx视频xxx69| 欧美老少配视频| 亚洲最大成人免费视频| 久久九九免费视频| 久久国产精品久久久久久久久久| 成人国产精品一区二区| 国产69精品久久久| 久久久久久久影视| 日韩成人av网| 91精品国产91久久久久福利| 91精品国产精品| 久久久av亚洲男天堂| 亚洲成**性毛茸茸| 亚洲第一视频网站| 久久全球大尺度高清视频| 1769国内精品视频在线播放| 久久久久久中文| 亚洲最新av在线网站| 久久久噜噜噜久久| 中文字幕不卡在线视频极品| 日本91av在线播放| 一区二区欧美在线| 97久久国产精品| 欧美日韩在线一区| 欧美一级大片在线观看| 一区二区三区天堂av| 97免费视频在线| 欧美性猛交xxx| 日韩精品在线播放| 久久精品欧美视频| 激情成人在线视频| 亚洲成成品网站| 欧美成在线观看| 久久久在线观看| 日韩av日韩在线观看| 亚洲免费电影一区| 国产精品视频网| 成人深夜直播免费观看| 国产日本欧美一区二区三区| 国产欧亚日韩视频| 日韩激情av在线播放| 亚洲性线免费观看视频成熟| 色与欲影视天天看综合网| 色青青草原桃花久久综合| 国产午夜精品一区理论片飘花| 成人免费网站在线观看| 亚洲男人av在线| 成人淫片在线看| 欧美大片在线看| 欧美一乱一性一交一视频| 亚洲欧美综合精品久久成人| 成人两性免费视频| 欧美性猛交99久久久久99按摩| 欧美激情视频一区二区| 69久久夜色精品国产69乱青草| 亚洲精品国产电影| 成人免费在线网址|