Monaco Editor 是微软开发的一个基于浏览器的代码编辑器,它可以提供代码高亮、智能感知、自动完成等功能。React 版本的 Monaco Editor 是一个 React 组件,可以在 React 应用中嵌入代码编辑器。
以下是一个简单的例子,展示如何在 React 应用中使用 Monaco Editor:
首先,安装 monaco-editor
包:
npm install monaco-editor
然后,创建一个 React 组件:
import React, { useEffect, useRef } from 'react';
import * as Monaco from 'monaco-editor';
const MonacoEditor = () => {
const editorRef = useRef(null);
useEffect(() => {
const editor = Monaco.editor.create(editorRef.current, {
value: ['function x() {', '\tconsole.log("Hello, world!");', '}'].join('\n'),
language: 'javascript',
theme: 'vs-dark'
});
// 组件卸载时销毁编辑器
return () => editor.dispose();
}, []);
return <div ref={editorRef} style={{ height: '400px', width: '100%' }} />;
};
export default MonacoEditor;
在上述代码中,我们创建了一个名为 MonacoEditor
的 React 函数组件。我们使用 useRef
来获取 DOM 元素的引用,并在 useEffect
钩子中初始化 Monaco Editor 实例。我们设置了编辑器显示的默认值和语言类型。最后,我们通过提供的 DOM 元素引用 editorRef.current
创建编辑器,并指定了编辑器的尺寸。
要注意的是,编辑器实例在组件卸载时应当被销毁,这是通过在 useEffect
钩子中返回一个清理函数来实现的。这样可以避免内存泄漏。