在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.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代碼高亮內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- highlight.js 代碼高亮插件的使用詳解
- Angular封裝WangEditor富文本組件的方法
- Vue中使用highlight.js實現代碼高亮顯示以及點擊復制
- Vue單頁面應用中實現Markdown渲染
- vue如何將字符串的一部分處理為html文檔並渲染到頁面