
react开发:中使用highlight.js将页面上的代码高亮。
下载highlight.js。
npm i highlight.js
导入highlight.js。
import hljs from 'highlight.js'
import 'highlight.js/styles/vs2015.css'
用highlight.js
useEffect(() => {
// 配置 highlight.js
hljs.configure({
// 忽略未经转义的 HTML 字符
ignoreUnescapedHTML: true
})
// 获取到内容中所有的code标签
const codes = document.querySelectorAll('pre code')
codes.forEach((el) => {
// 让code进行高亮
hljs.highlightElement(el as HTMLElement)
})
}, [])代码应用:
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>
)
} 





网友评论文明上网理性发言 已有0人参与
发表评论: