Vue3使用Monaco Editor实现python编辑器

什么是Monaco Editor?

​微软之前有个项目叫做Monaco Workbench,后来这个项目变成了VSCode,而Monaco Editor(下文简称monaco)就是从这个项目中成长出来的一个web编辑器,他们很大一部分的代码(monaco-editor-core)都是共用的,所以monaco和VSCode在编辑代码,交互以及UI上几乎是一摸一样的,有点不同的是,两者的平台不一样,monaco基于浏览器,而VSCode基于electron,所以功能上VSCode更加健全,并且性能比较强大。

开始使用

首先,我们需要安装monaco-editor和monaco-editor-webpack-plugin

npm install monaco-editor@0.30.0 -S
 
npm install monaco-editor-webpack-plugin@6.0.0 -D

然后进入vite.config.js文件,以下为代码片段

增加const MonacoWebpackPlugin = require(‘monaco-editor-webpack-plugin’);

configureWebpack: {
plugins: [
new MonacoWebpackPlugin({ languages: [‘python’,‘javascript’, ‘typescript’, ‘html’, ‘css’, ‘json’] })
]
},

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
const MonacoPlugin = require('monaco-editor-webpack-plugin');
 
export default defineConfig({
  plugins: [vue(),new MonacoPlugin({ languages: ['python','javascript', 'typescript', 'html', 'css', 'json'] })],
  )}

创建页面

接下来就可以直接开始使用了
记得导入才能使用

import * as monaco from 'monaco-editor';
<template>
        <div class="Content">
            <div ref="monacoEditorContainer" style="width:100%;height: 100%;"></div>
    </div>
</template>
<script lang="ts" setup>
import * as monaco from 'monaco-editor';
const monacoEditorContainer = ref(<any>null);
let editorInstance = ref(<any>null)

// 编辑器初始化
const editor = () => {
    editorInstance = monaco.editor.create(monacoEditorContainer.value, {
        theme: "vs-dark",
        value: '',
        language: "python",
        folding: true,
        foldingHighlight: true,
        foldingStrategy: "indentation",
        showFoldingControls: "always",
        disableLayerHinting: true,
        emptySelectionClipboard: false,
        selectionClipboard: false,
        automaticLayout: true,
        codeLens: false,
        scrollBeyondLastLine: false,
        colorDecorators: true,
        accessibilitySupport: "off",
        lineNumbers: "on",
        lineNumbersMinChars: 5,
        // enableSplitViewResizing: false,
        readOnly: false,
    });
}

// 获取编辑器内输入的内容
const getEditorContent=()=>{
    if (editorInstance) {
        const content = editorInstance.getValue();
        return content
    }
}

onMounted(() => {
    editor()
});
<script/>

进入页面,使用editor函数初始化编辑器,调用getEditorContent函数可以获取当前编辑器的内容,使用setValue函数可以给编辑器赋值

//给编辑器赋值
editorInstance.setValue("hello,world")

好了,快去试试吧。

  • 11
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

旭寒ls

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值