当前位置: 首页 > news >正文

Vite管理的Vue3项目中monaco editer的使用以及组件封装

文章目录

  • 背景
  • 环境说明
  • 安装流程以及组件封装
    • 引入依赖
    • 封装组件
  • 外部使用
    • 实现效果
  • v-model实现原理

背景

做oj系统的时候,需要使用代码编辑器,决定使用Monaco Editor,但是因为自身能力问题,读不懂官网文档,最终结合ai和网友的帖子成功引入,并封装了组件,支持v-model接收文档内容。希望可以帮助到别人。

环境说明

  • vite
  • vue3
  • pnpm

安装流程以及组件封装

引入依赖

pnpm install monaco-editor

封装组件

<script setup lang="ts">
import * as monaco from 'monaco-editor'
import { onMounted, ref } from 'vue'


// 容器对象
const editorContainer = ref()

// 编辑器对象
let codeEditor: monaco.editor.IStandaloneCodeEditor | null = null

// 声明一个input事件
const emit = defineEmits(['update:modelValue'])

// 从父组件中接收
const props = defineProps({
  language: {
    type: String,
    default: 'javascript'
  },
  modelValue: {
    type: String,
    default: '',
    required: true
  }
})

onMounted(() => {
  codeEditor = monaco.editor.create(editorContainer.value, {
    value: props.modelValue,
    language: props.language,
    lineNumbers: "on",
    roundedSelection: false,
    scrollBeyondLastLine: false,
    readOnly: false,
    theme: "vs",
    fontSize: 24
  })

  // 设置监听事件
  codeEditor.onDidChangeModelContent(() => {
    emit('update:modelValue', codeEditor?.getValue())
  })
})
</script>

<template>
  <div ref="editorContainer" style="height: 100%; width: 100%"/>
</template>

<style scoped>

</style>

外部使用

<script setup lang="ts">
import CodeEditor from '@/components/editor/CodeEditor/CodeEditor.vue'
import { ref } from 'vue'

// 编程语言
const codeLanguage = ref('java')

// 代码编辑器值
const text = ref('')

</script>

<template>
  <a-row>
    <a-col :span="22" :offset="1">
      <md-edit style="border: 1px black solid" @getMdEditText="getMdEditText" />
      <div style="height: 500px; width: 100%; border: 1px black solid">
        <code-editor :language="codeLanguage" v-model="text"/>
        获取到的值:
        {{ text }}
      </div>
    </a-col>
  </a-row>
</template>

实现效果

在这里插入图片描述

v-model实现原理

v-model本身是vue提供的一个语法糖。v-model = @update:modelValue + :modelValue。
即当父组件中的modelValue值发生改变时,通过:modelValue传入子组件,子组件对完成页面渲染。当子组件中的钩子函数被触发时(即编辑器中的值被改变时),通过emit触发update:modelValue事件,向父组件中传值,父组件中修改modelValue的值。

相关文章:

  • [Vue]事件修饰符
  • 7-2 sdut-C语言实验-逆序建立链表
  • HarmonyOS人脸比对技术自学指南与实战分享
  • MATLAB代码丨信号处理:对Python中Librosa库部分函数的重现
  • 命令执行GetShell
  • 【PGCCC】PostgreSQL Certified Master 个人专访 | 第二期 何雄
  • Linux使用集群服务器查看已安装conda环境,且环境名无显示、系统环境混乱等问题
  • 如何在 Linux 上安装并运行 Postman?
  • Vue 中如何使用 v-model 实现自定义组件的双向绑定?
  • 【深度学习新浪潮】展平RVQ技术详解
  • 2.0 项目管理前言
  • c++ primer 阅读手记 第四章
  • LangChain开发(四)服务监控(LangSmith、verbose、debug)
  • SQL中的左连接,体会一对多
  • android 图形开发的技能学习路线
  • 桥接模式的优点和典型实现
  • 套接字Socket
  • DeepSeek Smallpond 在火山引擎 AI 数据湖的探索实践
  • 【Axure高保真原型】纵向图片轮播
  • 如何在 HTML 中嵌入外部字体,有哪些注意事项?
  • 公司网站建设公司排名/网络推广渠道排名
  • 做游戏模型挣钱的网站/宁波seo推广如何收费
  • 加建网网站/关键词优化推广公司排名
  • wordpress只能在局域网/seog
  • 做网站公司名字应该用图片吗/我想做app推广代理
  • 今日头条网站模板/引流推广营销