html美化/格式化json字符串并显示

      /**
       * 美化json
       */
      function pretifyJson(json) {
         if (typeof json !== 'string') {
            json = JSON.stringify(json, undefined, 4);
         }
         let jsonStr = json.replace(/("(\\u[a-zA-Z0-9]{4}|\\[^u]|[^\\"])*"(\s*:)?|\b(true|false|null)\b|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?)/g,
                 function (match) {
                    let cls = "<span>";
                    if (/^"/.test(match)) {
                       if (/:$/.test(match)) {
                          cls = "<span class='key'>";
                       } else {
                          cls = "<span class='string'>";
                       }
                    } else if (/true|false/.test(match)) {
                       cls = "<span class='boolean'>";
                    } else if (/null/.test(match)) {
                       cls = "<span class='null'>";
                    }
                    return cls + match + "</span>";
                 }
         );
         
         let line = '<br/>&nbsp;&nbsp;&nbsp;&nbsp;';
         // 换行方式1 (低版本浏览器会出现死循环)
         jsonStr = jsonStr.replaceAll('</span>,', '</span>,' + line)
         .replaceAll('{<span', '{' + line + '<span')
         .replaceAll('</span>}', '</span>' + line + '}')

         // 换行方式2 (建议使用)
         jsonStr = jsonStr.split('</span>,').join('</span>,' + line)
                 .split('{<span').join('{' + line + '<span')
                 .split('</span>}').join('</span>' + line + '}');

         return jsonStr;
      }
      #data_info{
         width: 100%;
         font-size: 16px;
         white-space: pre-wrap;
         word-wrap: break-word;
         border:0px;
      }
      .string { color: green; }
      .number { color: darkorange; }
      .boolean { color: blue; }
      .null { color: magenta; }
      .key { color: red; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值