const 新字符串 = 目标字符串.replace(正则表达式,function(匹配结果) { return 对匹配到的内容的替换结果 })
const highLight = (str: string, keyword: string) => {
return str.replace(
new RegExp(keyword, 'gi'),
(match) => `<span>${match}</span>`
)
}
实现思路
通过 highlight.js 库实现对文章正文 HTML 中的代码元素自动添加语法高亮
示例
import hljs from 'highlight.js'
import 'highlight.js/styles/vs2015.css'
import { useEffect } from 'react'
export default function Question () {
useEffect(() => {
// 配置 highlight.js
hljs.configure({
// 忽略未经转义的 HTML 字符
ignoreUnescapedHTML: true
})
// 获取到内容中所有的code标签
const codes = document.querySelectorAll('.dg-html pre code')
codes.forEach((el) => {
// 让code进行高亮
hljs.highlightElement(el as HTMLElement)
})
}, [])
const content = `<pre>
<code>console.log(abc)</code>
<code>console.log(abc)</code>
</pre>
<h3>nihoa</h3>
<pre>
<code>console.log(abc);xxx.forEach(item=>{console.log(1)})</code>
</pre>`
return (
<div className="dg-html">
Question
<div dangerouslySetInnerHTML={{ __html: content }} />
</div>
)
}
操作步骤
安装包
npm i highlight.js
在页面中引入 highlight.js
import hljs from 'highlight.js'
import 'highlight.js/styles/vs2015.css'
在文章加载后,对文章内容中的代码进行语法高亮
原理
对pre>code元素添加样式类名
useEffect(() => {
// 配置 highlight.js
hljs.configure({
// 忽略未经转义的 HTML 字符
ignoreUnescapedHTML: true,
})
// 获取到内容中所有的code标签
const codes = document.querySelectorAll('.dg-html pre code')
codes.forEach((el) => {
// 让code进行高亮
hljs.highlightElement(el as HTMLElement)
})
}, [detail])