代码高亮"/>
在react中使用highlight.js将页面上的代码高亮
通过 highlight.js
库实现对文章正文 HTML 中的代码元素自动添加语法高亮,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.jshljs.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.jshljs.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>)
}
更多推荐
在react中使用highlight.js将页面上的代码高亮
发布评论