hljs和vkbeautify的xml,json代码高亮功能

最近有个需求是实现报文的一个展示,需要满足xml,json、普通字符串的展示及高亮,网上查阅资料后,使用hljs和vkbeautify组合的居多。
首先是vkbeautify,他是一个做格式化的工具,可以将xml、json字符串做格式化处理,处理后的字符串直接放入pre+code的标签就会直接显示格式化好的样子,hljs是一个做代码高亮的工具,他们搭配正好可以实现报文的格式化和高亮
使用方法很简单

import vkbeautify from "vkbeautify";
import hljs from "highlight.js/lib/core";
import xml from "highlight.js/lib/languages/xml";
import json from "highlight.js/lib/languages/json";
import plaintext from "highlight.js/lib/languages/plaintext";
//vscode风格的代码高亮
import "highlight.js/styles/vs2015.css";
hljs.registerLanguage("xml", xml);
hljs.registerLanguage("json", json);
hljs.registerLanguage("plaintext", plaintext);
//此处使用了按需引入的方式,hljs本身支持按需和全量,全量引入无需registerLanguage
//vkbeautify.xml() vkbeautify.json() 分别为对xml和json格式化
//对指定的el进行高亮
 document.querySelectorAll("pre code").forEach((el) => {
            hljs.highlightElement(el);
          });
<pre style={{ overflowX: "auto" }}>
                    <code data-type={index} className={"language-" + item.type}>
                    {/*item.code是通过vkbeautify 格式化后的string*/}
                      {item.code}
                    </code>
                    {/* <code className={"language-" + item.type}>{item.code}</code> */}
                  </pre>
需注意的点

1.vkbeautify.json方法格式化会调用JSON.parse,需考虑处理json格式不规范的error
2.hljs默认不进行换行处理,换行要加上.hljs{ white-space: pre-wrap; word-wrap: break-word; }
3.处理巨量内容时hljs会慢,可以考虑异步渲染,首先显示出内容,然后再异步调用 hljs.highlightElement

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值