通过 highlight.js 库实现对文章正文 html 中的代码元素自动添加语法高亮,highlight.js官方文档 下载highlight.js npm i highligh
通过 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.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>
)
}
到此这篇关于在react中使用highlight.js将页面上的代码高亮的方法的文章就介绍到这了,更多相关react highlight.js代码高亮内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: 在react中使用highlight.js将页面上的代码高亮的方法
本文链接: https://www.lsjlt.com/news/161777.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-01-12
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0