文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2024-04-02 19:55

关注

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 代码块插件

代码块插件

vscode扩展搜索 ES7 React/Redux/GraphQL/React-Native snippetsd或者React-Native/React/Redux snippets for es6/es7 并安装(如果安装后者 直接cccs可以一键生成模板块 安装前者 步骤如下)

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯