1.什么是Monaco Editor?Monaco Editor

微软之前有个项目叫做Monaco Workbench,后来这个项目变成了VSCode,而Monaco Editor(就是从这个项目中成长出来的一个web编辑器,他们很大一部分的代码(monaco-editor-core)都是共用的,所以monaco和VSCode在编辑代码,交互以及UI上几乎是一摸一样的。

VS Code(基于electron) 包含了文件管理、版本控制、插件等功能,是一款桌面软件

Monaco Editor (基于浏览器)可以看作是一个编辑器控件,只提供了基础的编辑器与语言相关的接口,可以被用于任何基于 Web 技术构建的项目中(不支持移动浏览器/移动 Web 框架)。

2.基础部件

Monaco Editor 的核心功能与组件和 VS Code 基本一致,它们基本上都包含下图中这些小部件。

  1. 行号

  2. Overlay Widget(覆盖窗口部件),可以渲染任意的内容小部件,能选择放置在顶部、底部或编辑器中间

  3. ViewLine,每一行都表示一个 ViewLine

  4. Decorations 装饰块,可以指定某个位置的代码块以何种样式呈现,例如修改其背景色、前景色等

  5. Content Widget(内容部件),与 Overlay Widget 类似,但可以基于行、列指定其位置。

  6. View Zone(查看区域), 与 Overlay、Content Widget 不同,它可以插入到特定的行之间将其撑开.

除了这些标配的部件之外,Monaco 还支持通过 Decorations API 来添加更多的装饰,例如版本控制中为修改过的行号添加一个色块,又或者在调试状态下显示断点信息等。

3.基础编辑功能

基本语法着色,多光标(ctr +shift + alt)

列框选择(shift + alt)

高级查找和替换(ctr + f),

格式化(shift + alt + F),

代码折叠

代码导航: 转到定义(ctr),类型定义, 查看引用等。

智能感知: 代码提示,补全, 验证功能

diff Editor: 差异编辑器

4. 语言支持

内置语言:javascript, css , dart, less, markdown, typescript, mysql, objective-c, python,  scheme, shell,sql,vb, xml,json,等

自定义:

Monaco 本身只是一个文本编辑器,对于不同编程语言的基础支持(即高亮)则需要通过注册语言规则的方式来实现,Monaco 默认使用了名为 Monarch 的高亮系统(而 VS Code 使用的则是 Textmate )(支持设置与vs code 一致的高亮方案, 参考 monaco-editor-textmate)

Monarch 规定了语言需要包含的关键字、类型、操作符,以及 Tokenizer。Tokenizer 是一组正则表达式,表示以何种规则来识别这些关键字以及括号、注释块,Monarch 将会依照正则表达式的配置来匹配每个 Token,并为之渲染对应的主题色。

5. 项目使用

  • 安装依赖
npm install monaco-editor
  • 组件引入 (按需引入, 全量引入)
// 按需引入
import 'monaco-editor/esm/vs/basic-languages/javascript/javascript.contribution'; // 引入javascript 语言
import 'monaco-editor/esm/vs/editor/contrib/find/browser/findController' // 搜索控件// 全量引入
import * as monaco from 'monaco-editor/esm/vs/editor/editor.api' // vue2 项目中
import * as monaco from 'monaco-editor' // vue3 项目中
  • 实例化
let options: monaco.editor.IStandaloneEditorConstructionOptions = {value: '', // 初始显示文字language: 'typescript', // 语言支持theme: 'vs', // 主题色官方自带: vs, hc-black , vs-darkautomaticLayout: true, // 自适应布局 默认truerenderLineHighlight: 'all', // 行亮方式 默认allselectOnLineNumbers: true, // 显示行号 默认trueminimap: {enabled: true,},readOnly: false, // 只读fontSize: 16, // 字体大小scrollBeyondLastLine: false, // 取消代码后面一大段空白overviewRulerBorder: false, // 不要滚动条的边框}
}
monaco.editor.create(cusEditor.value, options)
  • 代码补全和错误提示 ⽬前⽀持html,css,ts/js,json四种语⾔,我们只需要引⼊即可

Monaco的实现采用worker的方式,因为语法解析需要耗费大量时间,所以用worker来异步处理返回结果比较高效。

什么是web worker?web worker 详解

web worker是h5的一个新特性,是为了解决js(js是单线程的)在处理一些耗时任务时阻塞页面的渲染交互导致用户体验不好的问题,它的作用就是给JS创造多线程运行环境,允许主线程创建worker线程,分配任务给后者,主线程运行的同时worker线程也在运行,相互不干扰,在worker线程运行结束后把结果返回给主线程。这样主线程就会变得轻松,不会被阻塞或拖慢。不过因为worker一旦新建,就会一直运行,不会被主线程的活动打断,这样有利于随时响应主线程的通信,但是也会造成资源的浪费,所以不应过度使用,用完注意关闭。

webpack项目配置 

借助monaco-editor-webpack-plugin插件,它会帮我们做这么⼏件事
1. ⾃动注⼊getWorkerUrl全局变量
2. 处理worker的编译配置
3. ⾃动引⼊控件和语⾔包

安装依赖

npm install monaco-editor-webpack-plugin -S

webpack配置

const MonacoWebpackPlugin = require('monaco-editor-webpack-plugin');
module.exports=function(){return {...plugins:[// 具体引入哪些语言和控件配置(未配置默认引入全部)new MonacoWebpackPlugin({languages:["javascript","css","html","json"],features:["coreCommands","find"]})]...}
}

vite项目配置  参考 vite解决Monaco 引入问题

import * as monaco from 'monaco-editor';
import editorWorker from 'monaco-editor/esm/vs/editor/editor.worker?worker';
import jsonWorker from 'monaco-editor/esm/vs/language/json/json.worker?worker';
import cssWorker from 'monaco-editor/esm/vs/language/css/css.worker?worker';
import htmlWorker from 'monaco-editor/esm/vs/language/html/html.worker?worker';
import tsWorker from 'monaco-editor/esm/vs/language/typescript/ts.worker?worker';
// @ts-ignore: worker 导入方式可以参考vite官网 https://cn.vitejs.dev/guide/features.html#web-workers
self.MonacoEnvironment = { // 提供一个定义worker路径的全局变量getWorker(_: any, label: string) {if (label === 'json') {return new jsonWorker();}if (label === 'css' || label === 'scss' || label === 'less') {return new cssWorker();}if (label === 'html' || label === 'handlebars' || label === 'razor') {return new htmlWorker();}if (label === 'typescript' || label === 'javascript') {return new tsWorker();}return new editorWorker(); // 基础功能文件, 提供了所有语言通用功能 无论使用什么语言,monaco都会去加载他。}
};monaco.languages.typescript.typescriptDefaults.setEagerModelSync(true);

Monaco Editor (vite/webpack + ts + vue项目使用)相关推荐

  1. 从零开始使用webpack 搭建vue项目

    从零开始使用webpack 搭建vue项目 1 创建项目 npm init 生成 package.json 创建 index.html webpack.confug.js project-name|- ...

  2. vite+vue3+ts+element-plus项目搭建--超详细

    vite+vue3+ts+element-plus项目搭建–超详细 vite 作用 快速的冷启动:不需要等待打包操作: 即时的热模块更新:替换性能和模块数量的解耦让更新飞起: 真正的按需编译:不再等待 ...

  3. 提高 webpack 构建 Vue 项目的速度

    提高 webpack 构建 Vue 项目的速度 前言 最近有人给我的 Vue2 后台管理系统解决方案 提了 issue ,说执行 npm run build 构建项目的时候极其慢,然后就引起我的注意了 ...

  4. webpack打包vue项目之后dist文件夹在本地跑起来

    webpack打包vue项目之后dist文件夹在本地跑起来 转载为:https://blog.csdn.net/u014054437/article/details/79981307 谢谢博主 亲测, ...

  5. 用 vue-cli 手脚架 建立一个 webpack 模板 vue 项目

    用 vue-cli 手脚架 建立一个 webpack 模板 vue 项目 一:vue 环境安装 如果环境安装好了,可以直接用vue-cli手脚架生成 模板项目, 一般用的是webpack模板. 1.去 ...

  6. 使用webpack打包vue项目

    使用webpack打包vue项目 安装webpack工具,安装方式有两种:全局安装(命令:npm install -g webpack webpack-cli)以及安装在项目中,这里使用第二种: // ...

  7. webpack搭建vue项目(不用脚手架)

    webpack搭建vue项目(不用脚手架) npm默认安装的是最新版本,这里讲的是Webpack4用法,如果遇到问题请检查是否是版本问题 webpack5升级了一些东西,例如图片的打包 1.初始化项目 ...

  8. 如何创建基于webpack的vue项目和基于vite的vue项目及将现有vue项目变更为基于vite项目

    基于新电脑实现步骤如下 1.如果这些都安装好了可以直接进入下一步,安装npm,分别敲入如下命令 /bin/zsh -c "$(curl -fsSL https://gitee.com/cun ...

  9. vite+vue3+ts项目搭建之集成qiankun让其成为子应用模板(vite+vue3+ts+qiankun项目)—新增主应用在线地址可以进入vue2/vue3子应用

    前言 以下操作,是续接之前 第四步 --即:vite+vue3+ts+pinia+element-plus项目已完成搭建好,可以直接业务开发了 主应用技术栈:vue2+webpack+js 集成qia ...

最新文章

  1. Kotlin学习 PART 3:类,对象和接口
  2. HTML5 新元素标签系列:最简版 HTML5
  3. Shell脚本自动监控docker容器的状态
  4. 细说说傲腾与哈娜的那些事儿
  5. C#测量程序运行时间及cpu使用时间(转)
  6. hbase linux 命令,在linux下操作hbase
  7. delphi文本转换mp3_基于百度AI 的语音合成、转换的 Yii2 sdk.
  8. MAGENTO DEBUG
  9. 动态生成和移除img标签---JavaScript
  10. QLineEdit屏蔽扫描枪输入自带回车的方法
  11. java类private_Java访问类中private属性和方法
  12. 08#wordcloud2包 词云生成器
  13. 取消UOS双系统开机启动
  14. postgreSql数据库笔记
  15. 服务器信息未初始化失败怎么办,初始化服务器失败
  16. 王半仙儿的日记-0009
  17. python中average什么意思_在Python3 numpy中mean和average的区别详解
  18. 足球人生:青春不过几届世界杯
  19. App纳入监管,HTML5将大行其道?
  20. html如何添加多个视频教程,html多格式视频教程

热门文章

  1. 小米手机视频工具箱详细设置方法分享
  2. 03 pyecharts 直角坐标系图表(示例代码+效果图)
  3. 备份android分区,使用 adb 备份技术提取 Android APP 的 data 分区内容 – 星云软件工作室产品研发团队...
  4. android 电子菜谱,电子菜谱 E-menu(单机版)
  5. 腾讯智慧校园 php,【腾讯智慧校园V1.32】更新
  6. NK.bin与NK.nb0格式
  7. 每天学一点flash(5) actionscript 3.0 外部加载mp3音乐
  8. HTML网页小游戏 算术题判断
  9. java版本微信机器人使用教程V1.0
  10. Python pandas模块