react中代码块输出,代码高亮显示,带行号,能复制的问题

 更新时间:2022年09月21日 11:08:29   作者:酷jjs  
这篇文章主要介绍了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 = "<ul id='ulcode'><li>" + block.innerHTML.replace(/\n/g, "\n</li><li>") + " </li></ul>";
      });
    }
  }, [visible])
 
  const handleCopy = () => {
    message.success('复制成功!')
  };
 
  return <div>
    <Modal title={title} visible={visible} onCancel={handleCancel} onOk={handleOk}
      footer={[
        <CopyToClipboard text={JSON.stringify(data, null, 2)} onCopy={handleCopy}>
          <Button>复制</Button>
        </CopyToClipboard>,
        <Button key="submit" type="primary" onClick={handleCancel}>确定</Button>
      ]}
    >
      <Highlight className="javascript mycode" >
        {JSON.stringify(data, null, 2)}
      </Highlight>
    </Modal>
  </div>;
}

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可以一键生成模板块 安装前者 步骤如下)

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • React实现控制减少useContext导致非必要的渲染详解

    React实现控制减少useContext导致非必要的渲染详解

    这篇文章主要介绍了React如何有效减少使用useContext导致的不必要渲染,使用useContext在改变一个数据时,是通过自己逐级查找对比改变的数据然后渲染,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-11-11
  • React router动态加载组件之适配器模式的应用详解

    React router动态加载组件之适配器模式的应用详解

    这篇文章主要介绍了React router动态加载组件之适配器模式的应用 ,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-09-09
  • 基于React+Redux的SSR实现方法

    基于React+Redux的SSR实现方法

    这篇文章主要介绍了基于React+Redux的SSR实现方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-07-07
  • React大文件分片上传原理及方案

    React大文件分片上传原理及方案

    前端进行大文件分片上传的方案几乎都是利用Blob.prototype.slice方法对文件进行分片,用数组将每一个分片存起来,最后将分片发给后端,本文给大家介绍React大文件分片上传方案,感兴趣的朋友跟随小编一起看看吧
    2023-08-08
  • React中的useState和setState的执行机制详解

    React中的useState和setState的执行机制详解

    这篇文章主要介绍了React中的useState和setState的执行机制,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • react中实现拖拽排序react-dnd功能

    react中实现拖拽排序react-dnd功能

    这篇文章主要介绍了react中实现拖拽排序react-dnd功能,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-02-02
  • 一起来了解React的Hook

    一起来了解React的Hook

    这篇文章主要为大家详细介绍了React的Hook,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • React 函数式组件和类式组件详情

    React 函数式组件和类式组件详情

    这篇文章主要介绍了React函数式组件和类式组件详情,React是组件化的的JS库,组件化也是React的核心思想,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-08-08
  • react 路由权限动态菜单方案配置react-router-auth-plus

    react 路由权限动态菜单方案配置react-router-auth-plus

    这篇文章主要为大家介绍了react路由权限动态菜单方案react-router-auth-plus傻瓜式配置详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • 详解React中合并单元格的正确写法

    详解React中合并单元格的正确写法

    用表格进行页面布局,页面布局在各种浏览器的的兼容性, 本文主要介绍了详解React中合并单元格的正确写法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-01-01

最新评论