react中使用codeMirror之代码对比方法:codeMirror.mergeView()

2023-10-22 04:08

本文主要是介绍react中使用codeMirror之代码对比方法:codeMirror.mergeView(),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

codeMirror是一个很强大的代码编辑器,其中的mergeView方法可以进行代码的对比

官网地址:https://codemirror.net/
gitHub地址:https://github.com/codemirror/CodeMirror
参考:https://www.jianshu.com/p/2ba3cf5057c6

使用

1.下载codemirror

npm install codemirror

2,在需要使用的页面引入codeMirror。我一般是封装成一个组件,需要用的时候直接引入即可

import CodeMirror from 'codemirror';//引入codeMirror
import 'codemirror/addon/merge/merge.css';//引入codeMirror样式

3,依赖

依赖地址:https://cdnjs.cloudflare.com/ajax/libs/diff_match_patch/20121119/diff_match_patch.js
import './diff_match_patch';//codeMirror的比对是依赖于google的这个插件来实现的,但是在codeMirror底层并没有这个插件,所以要自行引入,我这里是下载到了本地之后再引入的

4,对比(如果要实现对比功能,必须引入下面两个文件)

import 'codemirror/addon/merge/merge.css';
import 'codemirror/addon/merge/merge.js';

5,mode

import 'codemirror/mode/javascript/javascript'
import 'codemirror/mode/xml/xml'
import 'codemirror/mode/python/python'
import 'codemirror/mode/markdown/markdown'
。。。。。

6.fold

import "codemirror/addon/fold/foldgutter.css"
import "codemirror/addon/fold/foldcode"
import "codemirror/addon/fold/brace-fold"//折叠js
import "codemirror/addon/fold/xml-fold"//折叠xml和html
import "codemirror/addon/fold/markdown-fold"//折叠md
import "codemirror/addon/fold/comment-fold"//折叠注释,但是测试一下只能折叠html的注释;

7.active-line

import "codemirror/addon/selection/active-line"

5,代码比对插件就完成了最基础的文件引入,下一步是在react中使用

class CodeMirrors extends Component{constructor(props) {super(props);this.state= {FileContentData: props.FileContentData,}}componentDidMount(){const {FileContentData} = this.propsthis.initUI(FileContentData)}initUI(data) {var target = this.refs['react-diff-code-view'];//获取dom元素console.log(target)target.innerHTML = "";//每次dom元素的内容清空CodeMirror.MergeView(target, Object.assign({}, {readOnly: true,//只读lineNumbers: true, // 显示行号theme: 'eclipse', //设置主题value: data.lhContent,//左边的内容(新内容)orig: data.rhContent,//右边的内容(旧内容)mode: "javascript",//代码模式为js模式,这里还可以是xml,python,java,等等,会根据不同代码模式实现代码高亮highlightDifferences: "highlight",//有差异的地方是否高亮connect: null,revertButtons: false,//revert按钮设置为true可以回滚styleActiveLine: true,//光标所在的位置代码高亮lineWrap:true,// 文字过长时,是换行(wrap)还是滚动(scroll),默认是滚动smartIndent: true, // 智能缩进matchBrackets: true, // 括号匹配foldGutter:true,//代码折叠gutters: ["CodeMirror-linenumbers", "CodeMirror-foldgutter"]// 智能提示extraKeys:{"Alt-/": "autocomplete", "F11": function (cm) {cm.setOption("fullScreen", !cm.getOption("fullScreen"));}}}, this.props.options || {}));}render(){return (<div className="react-diff-code-view" style={{height: '100%'}}><div ref="react-diff-code-view" style={{height: '100%'}</div></div>)}
}
export default CodeMirrors;

bug1:当这个组件在另外一个页面使用时,由于reder会执行两次,一次是旧的state,一次是新的state,但是codeMirror组件的componentDidMount只执行一次就必须想办法在别的生命周期函数里面去执行initUI函数,以获取最新的数据

  componentWillReceiveProps(nextProps){this.initUI(nextProps.FileContentData);}

bug2:很多同学下载完codeMirror之后根本找不到mergeView这个方法,原因是下载工具npm或者是tnpm/cnpm不稳定,你的node_modules包根本就没有下载好,重新npm下载或者直接把整个codeMirror的文件downLoad到本地,放在lib里面

对比图基本如下
在这里插入图片描述

tip1:修改有差异的背景颜色
  .CodeMirror-merge-r-chunk { background: rgba(30,144,255,0.5); }.CodeMirror-merge-r-chunk-start { border-top: 1px solid dodgerblue; }.CodeMirror-merge-r-chunk-end { border-bottom: 1px solid dodgerblue; }.CodeMirror-merge-r-connect { fill: rgba(30,144,255,0.5); stroke: rgba(30,144,255,0.5); stroke-width: 1px; }.CodeMirror-merge-l-chunk { background: rgba(30,144,255,0.5); }.CodeMirror-merge-l-chunk-start { border-top: 1px solid dodgerblue; }.CodeMirror-merge-l-chunk-end { border-bottom: 1px solid dodgerblue; }.CodeMirror-merge-l-connect { fill: rgba(30,144,255,0.5); stroke: rgba(30,144,255,0.5); stroke-width: 1px; }.CodeMirror-merge-l-chunk { background: rgba(30,144,255,0.5); }.CodeMirror-merge-r-chunk { background: rgba(30,144,255,0.5); }.CodeMirror-merge-l-chunk-start { border-top: 1px solid dodgerblue; }.CodeMirror-merge-r-chunk-start { border-top: 1px solid dodgerblue; }.CodeMirror-merge-l-chunk-end { border-bottom: 1px solid dodgerblue; }.CodeMirror-merge-r-chunk-end { border-bottom: 1px solid dodgerblue; }

这篇关于react中使用codeMirror之代码对比方法:codeMirror.mergeView()的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/258953

相关文章

Python如何去除图片干扰代码示例

《Python如何去除图片干扰代码示例》图片降噪是一个广泛应用于图像处理的技术,可以提高图像质量和相关应用的效果,:本文主要介绍Python如何去除图片干扰的相关资料,文中通过代码介绍的非常详细,... 目录一、噪声去除1. 高斯噪声(像素值正态分布扰动)2. 椒盐噪声(随机黑白像素点)3. 复杂噪声(如伪

Java Spring ApplicationEvent 代码示例解析

《JavaSpringApplicationEvent代码示例解析》本文解析了Spring事件机制,涵盖核心概念(发布-订阅/观察者模式)、代码实现(事件定义、发布、监听)及高级应用(异步处理、... 目录一、Spring 事件机制核心概念1. 事件驱动架构模型2. 核心组件二、代码示例解析1. 事件定义

python使用库爬取m3u8文件的示例

《python使用库爬取m3u8文件的示例》本文主要介绍了python使用库爬取m3u8文件的示例,可以使用requests、m3u8、ffmpeg等库,实现获取、解析、下载视频片段并合并等步骤,具有... 目录一、准备工作二、获取m3u8文件内容三、解析m3u8文件四、下载视频片段五、合并视频片段六、错误

Python中提取文件名扩展名的多种方法实现

《Python中提取文件名扩展名的多种方法实现》在Python编程中,经常会遇到需要从文件名中提取扩展名的场景,Python提供了多种方法来实现这一功能,不同方法适用于不同的场景和需求,包括os.pa... 目录技术背景实现步骤方法一:使用os.path.splitext方法二:使用pathlib模块方法三

Python打印对象所有属性和值的方法小结

《Python打印对象所有属性和值的方法小结》在Python开发过程中,调试代码时经常需要查看对象的当前状态,也就是对象的所有属性和对应的值,然而,Python并没有像PHP的print_r那样直接提... 目录python中打印对象所有属性和值的方法实现步骤1. 使用vars()和pprint()2. 使

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比

《CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比》CSS中的position属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布... css 中的 position 属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布局和层叠关

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

nginx启动命令和默认配置文件的使用

《nginx启动命令和默认配置文件的使用》:本文主要介绍nginx启动命令和默认配置文件的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录常见命令nginx.conf配置文件location匹配规则图片服务器总结常见命令# 默认配置文件启动./nginx