使用正则表达式的格式化与高亮显示json字符串_javascript技巧
json字符串很有用,有时候一些后台接口返回的信息是字符串格式的,可读性很差,这个时候要是有个可以格式化并高亮显示json串的方法那就好多了,下面看看一个正则表达式完成的json字符串的格式化与高亮显示
首先是对输入进行转换,如果是对象则转化为规范的json字符串,不是对象时,先将字符串转化为对象(防止不规范的字符串),然后再次转化为json串。其中json为输入。
if (typeof json !== 'string') {
json = JSON.stringify(json);
} else {
json = JSON.parse(json);
json = JSON.stringify(json);
}
等规范完数据之后对字符串进行标记,为了后面的切分、重新组合
这里有几个地方要添加标记,包括大括号、小括号的前后和逗号的后面都要添加标记,我这里使用的是换行 \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,"$1");
node = node.replace(/([\[\]])/g,"$1");
node = node.replace(/(\".*\")(\:)(.*)(\,)?/g,"$1$2$3$4");
node = node.replace(/\"([^"]*)\"(\,)?$/g,"\"$1\"$2");
node = node.replace(/(-?\d+)(\,)?$/g,"$1$2");
最后我们看看完整的方法代码(这里我使用了jquery类库),以及测试地址:
要对jsonstr进行美化,这样就可以了APP.format(jsonstr),直接输出至
下面是一个测试地址,http://iforever.sinaapp.com/ 可以进去试一下,看看完整的源代码
<script><br /> var APP=function(){<br /> var format=function(json){<br /> var reg=null,<br /> result='';<br /> pad=0,<br /> PADDING=' ';<br /> if (typeof json !== 'string') {<br /> json = JSON.stringify(json);<br /> } else {<br /> json = JSON.parse(json);<br /> json = JSON.stringify(json);<br /> }<br /> // 在大括号前后添加换行<br /> reg = /([\{\}])/g;<br /> json = json.replace(reg, '\r\n$1\r\n');<br /> // 中括号前后添加换行<br /> reg = /([\[\]])/g;<br /> json = json.replace(reg, '\r\n$1\r\n');<br /> // 逗号后面添加换行<br /> reg = /(\,)/g;<br /> json = json.replace(reg, '$1\r\n');<br /> // 去除多余的换行<br /> reg = /(\r\n\r\n)/g;<br /> json = json.replace(reg, '\r\n');<br /> // 逗号前面的换行去掉<br /> reg = /\r\n\,/g;<br /> json = json.replace(reg, ',');<br /> //冒号前面缩进<br /> reg = /\:/g;<br /> json = json.replace(reg, ': ');<br /> //对json按照换行进行切分然后处理每一个小块<br /> $.each(json.split('\r\n'), function(index, node) {<br /> var i = 0,<br /> indent = 0,<br /> padding = '';<br /> //这里遇到{、[时缩进等级加1,遇到}、]时缩进等级减1,没遇到时缩进等级不变<br /> if (node.match(/\{$/) || node.match(/\[$/)) {<br /> indent = 1;<br /> } else if (node.match(/\}/) || node.match(/\]/)) {<br /> if (pad !== 0) {<br /> pad -= 1;<br /> }<br /> } else {<br /> indent = 0;<br /> }<br /> //padding保存实际的缩进<br /> for (i = 0; i < pad; i++) {<br /> padding += PADDING;<br /> }<br /> //添加代码高亮<br /> node = node.replace(/([\{\}])/g,"<span class='ObjectBrace'>$1");<br /> node = node.replace(/([\[\]])/g,"<span class='ArrayBrace'>$1");<br /> node = node.replace(/(\".*\")(\:)(.*)(\,)?/g,"<span class='PropertyName'>$1$2$3$4");<br /> node = node.replace(/\"([^"]*)\"(\,)?$/g,"<span class='String'>\"$1\"<span class='Comma'>$2");<br /> node = node.replace(/(-?\d+)(\,)?$/g,"<span class='Number'>$1<span class='Comma'>$2");<br /> result += padding + node + '<br>';<br /> pad += indent;<br /> });<br /> return result;<br /> };<br /> return {<br /> "format":format,<br /> };<br /> }();<br /> </script>
怎么样,json字符串是不是美观了很多呢,超级实用吧,这么好的东东,当然不能独享,这里推荐给小伙伴们。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

DOS命令是一种在Windows操作系统中使用的命令行工具,它可以用于执行各种系统管理任务和操作。其中一个常用的任务是格式化硬盘驱动器,包括C盘。格式化C盘是一个比较危险的操作,因为它将会清除C盘上的所有数据,并将文件系统重新初始化。在执行这个操作之前,确保你已经备份了重要的文件,并且清楚地了解格式化操作对你的计算机会产生的影响。下面是在DOS命令行中格式化

现如今,无法开机等,卡顿,我们难免会遇到一些问题,比如系统崩溃、但在使用过程中、手机已成为我们生活中不可或缺的一部分。我们往往束手无策、而有时、对于这些问题的解决方法。帮助你解决手机故障,本文将为大家介绍一些手机格式化恢复的方法、让手机重新恢复正常运行。备份数据——保护重要信息安全通讯录等,如照片、联系人、以免在格式化过程中丢失、在进行手机格式化之前、首先要考虑的是备份手机上的重要数据和文件。确保数据的安全性、或者选择将文件传输至云存储服务中,可以通过连接电脑进行备份。使用系统自带恢复功能——简

格式化笔记本电脑会使其速度更快吗?如果您想格式化您的Windows笔记本电脑,但想知道它是否会使速度更快,本文将帮助您了解这个问题的正确答案。格式化笔记本电脑会使其速度更快吗?用户格式化Windows笔记本电脑的原因有很多。但最常见的原因是笔记本电脑的性能或速度缓慢。格式化笔记本电脑会彻底删除C盘或安装Windows操作系统的硬盘分区上存储的所有数据。因此,每个用户在采取这一步之前都会三思而后行,尤其是在笔记本电脑的性能方面。本文将帮助您了解格式化笔记本电脑是否会加快速度。格式化笔记本电脑有助于

PHP正则表达式验证:数字格式检测在编写PHP程序时,经常需要对用户输入的数据进行验证,其中一个常见的验证是检查数据是否符合指定的数字格式。在PHP中,可以使用正则表达式来实现这种验证。本文将介绍如何使用PHP正则表达式来验证数字格式,并提供具体的代码示例。首先,让我们看一下常见的数字格式验证要求:整数:只包含数字0-9,可以以正负号开头,不包含小数点。浮点

要使用正则表达式在Golang中验证电子邮件地址,请执行以下步骤:使用regexp.MustCompile创建一个正则表达式模式,匹配有效的电子邮件地址格式。使用MatchString函数检查字符串是否与模式匹配。该模式涵盖了大多数有效的电子邮件地址格式,包括:局部用户名可以包含字母、数字和特殊字符:!.#$%&'*+/=?^_{|}~-`域名至少包含一个字母,后面可以跟字母、数字或连字符顶级域名(TLD)不能超过63个字符长

html格式化方法:1、使用在线HTML格式化工具;2、使用代码编辑器自带的HTML格式化快捷键,如Visual Studio Code中的Shift + Alt + F;3、使用插件,如Sublime Text中的HTML/CSS/JS Prettify插件;4、使用命令行工具,如HTML Tidy;5、手动格式化,按照编码规范和习惯进行手动格式化。

PHP正则表达式:精确匹配与排除模糊包含正则表达式是一种强大的文本匹配工具,能够帮助程序员在处理文本时进行高效的搜索、替换和筛选。在PHP中,正则表达式也被广泛应用于字符串处理和数据匹配中。本文将重点介绍在PHP中如何进行精确匹配和排除模糊包含的操作,同时结合具体的代码示例进行说明。精确匹配精确匹配意味着只匹配符合完全条件的字符串,不匹配任何变种或包含额外字

在Go中,可以使用正则表达式匹配时间戳:编译正则表达式字符串,例如用于匹配ISO8601时间戳的表达式:^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(\.\d+)?(Z|[+-][0-9]{2}:[0-9]{2})$。使用regexp.MatchString函数检查字符串是否与正则表达式匹配。
