国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

使用正則表達(dá)式的格式化與高亮顯示json字符串

2019-11-20 13:50:16
字體:
供稿:網(wǎng)友

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

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

復(fù)制代碼 代碼如下:

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)記,包括大括號(hào)、小括號(hào)的前后和逗號(hào)的后面都要添加標(biāo)記,我這里使用的是換行/r/n(這樣在命令行下測試時(shí)效果會(huì)比較好看)。

復(fù)制代碼 代碼如下:

// 在大括號(hào)前后添加換行
reg = /([/{/}])/g;
json = json.replace(reg, '/r/n$1/r/n');
// 中括號(hào)前后添加換行
reg = /([/[/]])/g;
json = json.replace(reg, '/r/n$1/r/n');
// 逗號(hào)后面添加換行
reg = /(/,)/g;
json = json.replace(reg, '$1/r/n');

添加完成標(biāo)記之后就要做一些優(yōu)化處理,去掉多余的換行、去掉逗號(hào)前面的換行,這樣做是為了在切分是免得出現(xiàn)空串浪費(fèi)一次循環(huán)處理,最后在冒號(hào)后面添加空格,看起來更漂亮。

復(fù)制代碼 代碼如下:

// 去除多余的換行
reg = /(/r/n/r/n)/g;
json = json.replace(reg, '/r/n');
// 逗號(hào)前面的換行去掉
reg = //r/n/,/g;
json = json.replace(reg, ',');
//冒號(hào)前面縮進(jìn)
reg = //:/g;
json = json.replace(reg, ': ');

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

復(fù)制代碼 代碼如下:

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

首先說下縮進(jìn),縮進(jìn)的方法很簡單,遇到{、[符號(hào)時(shí)縮進(jìn)增加1,遇到}、]符號(hào)時(shí)縮進(jìn)減少1,否則縮進(jìn)量不變。

復(fù)制代碼 代碼如下:

//這里遇到{、[時(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)行判斷,如果匹配到大括號(hào)標(biāo)記為對象class、中括號(hào)標(biāo)記為數(shù)組class、屬性名稱、屬性值,一次對這些進(jìn)行css規(guī)則添加,添加完成之后拼接起來就可以了。

復(fù)制代碼 代碼如下:

.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;}

復(fù)制代碼 代碼如下:

//添加代碼高亮
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)去試一下,看看完整的源代碼

復(fù)制代碼 代碼如下:

<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);
            }
            // 在大括號(hào)前后添加換行
            reg = /([/{/}])/g;
            json = json.replace(reg, '/r/n$1/r/n');
            // 中括號(hào)前后添加換行
            reg = /([/[/]])/g;
            json = json.replace(reg, '/r/n$1/r/n');
            // 逗號(hào)后面添加換行
            reg = /(/,)/g;
            json = json.replace(reg, '$1/r/n');
            // 去除多余的換行
            reg = /(/r/n/r/n)/g;
            json = json.replace(reg, '/r/n');
            // 逗號(hào)前面的換行去掉
            reg = //r/n/,/g;
            json = json.replace(reg, ',');
            //冒號(hào)前面縮進(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>

怎么樣,json字符串是不是美觀了很多呢,超級實(shí)用吧,這么好的東東,當(dāng)然不能獨(dú)享,這里推薦給小伙伴們。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 榆树市| 华亭县| 吴桥县| 稷山县| 凌海市| 万载县| 南京市| 信阳市| 博罗县| 青岛市| 黑河市| 竹北市| 扶风县| 蒲城县| 上蔡县| 法库县| 凉城县| 庆城县| 上蔡县| 闻喜县| 巴林左旗| 遵化市| 兰溪市| 喜德县| 华阴市| 河池市| 绥阳县| 团风县| 兰坪| 常德市| 黄梅县| 波密县| 巩义市| 孟连| 额尔古纳市| 安化县| 大洼县| 宁化县| 曲阜市| 上蔡县| 南江县|