在react中使用highlight.js将页面上的代码高亮的方法
更新时间:2022年01月06日 16:28:22 作者:留着鼻涕敲代码
本文通过 highlight.js 库实现对文章正文 HTML 中的代码元素自动添加语法高亮,具有一定的参考价值,感兴趣的可以了解一下
通过 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代码高亮内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
解决React报错Cannot find namespace context
这篇文章主要为大家介绍了React报错Cannot find namespace context分析解决,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-12-12React如何使用refresh_token实现无感刷新页面
本文主要介绍了React如何使用refresh_token实现无感刷新页面,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2022-04-04JavaScript的React Web库的理念剖析及基础上手指南
这篇文章主要介绍了JavaScript的React Web库的理念剖析及基础上手指南,React Web的目的即是把本地的React Native应用程序项目变为Web应用程序,需要的朋友可以参考下2016-05-05
最新评论