您现在的位置是:网站首页> 编程资料编程资料
react中代码块输出,代码高亮显示,带行号,能复制的问题_React_
2023-05-24
297人已围观
简介 react中代码块输出,代码高亮显示,带行号,能复制的问题_React_
react 代码块输出,代码高亮显示,带行号,能复制
以modal组件为例
import React, { useState, useEffect } from 'react'; import { Modal, Button, message } from 'antd'; import Highlight from 'react-highlight'; import "highlight.js/styles/mono-blue.css"; import { CopyToClipboard } from 'react-copy-to-clipboard'; import "./infoModal.less"; import hljs from 'highlight.js'; export default function infoModal(props: any) { const { visible, handleCancel, handleOk, modalType } = props; const [title, setIitle] = useState(''); const [num, setNum] = useState(0); const [data, setData] = useState({ "a": title, "a2": "1", "a3": "1", "a4": "1", "a5": "1", "a6": "1", "a7": "1", "a8": "1", "a9": "1", }); useEffect(() => { if (modalType === "in") { setIitle("入参信息") } else { setIitle("出参信息") }; }, [modalType]); //显示行号 useEffect(() => { if (visible) { hljs.initHighlightingOnLoad(); document.querySelectorAll('pre code').forEach((block) => { block.innerHTML = "- " + block.innerHTML.replace(/\n/g, "\n
- ") + "
infoModal.less样式
.hljs ul { list-style: decimal; margin: 0 0 0 40px!important; padding: 0 } .hljs li { list-style: decimal-leading-zero; border-left: 1px solid #333!important; padding: 2px 5px!important; margin: 0!important; line-height: 14px; width: 100%; box-sizing: border-box } .hljs li:nth-of-type(even) { background-color: rgba(255,255,255,.015); color: inherit } .javascript{ max-height:400px; }效果图:

- 代码块显示:react-highlight插件
- 代码块复制:react-copy-to-clipboard插件
- 代码块显示行号:highlight.js插件+js代码(上文中已注释)+less样式(上文中已添加)
react 代码块插件
代码块插件
vscode扩展搜索 ES7 React/Redux/GraphQL/React-Native snippetsd或者React-Native/React/Redux snippets for es6/es7 并安装(如果安装后者 直接cccs可以一键生成模板块 安装前者 步骤如下)

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
相关内容
- TypeScript 内置高级类型编程示例_JavaScript_
- vue Keep-alive组件缓存的简单使用代码_vue.js_
- Vue.js如何获取data-*的值_vue.js_
- 详解Anyscript开发指南绕过typescript类型检查_JavaScript_
- vue使用keep-alive进行组件缓存方法详解(组件不缓存问题解决)_vue.js_
- vue3 HighCharts自定义封装之径向条形图的实战过程_vue.js_
- 详解React Native项目中启用Hermes引擎_React_
- JSON数组和JSON对象在vue中的获取方法_vue.js_
- Vue中如何获取json文件中的数据_vue.js_
- vue引用json文件的方法小结_vue.js_
