为什么要写这篇文章?

最近开发了一个简单的在线代码编辑器,基于 Monaco Editor 实现,没有了解过 Monaco 的人可能不知道,我们常用的 VS Code 也是基于它实现的~

回到正题,Monaco Editor 有一份完整的官方文档,那为什么还要写这个文章?因为官方文档是在是太难用了,api 难找不说,找到了也是看得云里雾里,可能是我查阅的姿势不对吧,欢迎有文档使用经验的朋友在评论中指教~

话不多说,下面开始总结我在开发中的常用功能。

开始使用

我使用的是 Vue 版本的包 monaco-editor-vue,使用方式如下:

theme="vs-dark"

language="javascript"

:editorMounted="onEditorMounted"

:options="options"

@change="onChange"

>

export default {

name: "App",

components: {

MonacoEditor

},

data() {

return {

options: {

value: '', // 初始值

foldingStrategy: 'indentation', // 代码可分小段折叠

automaticLayout: true, // 自适应布局

overviewRulerBorder: false, // 不要滚动条的边框

autoClosingBrackets: true,

tabSize: 2, // tab 缩进长度

minimap: {

enabled: false, // 不要小地图

},

},

}

},

methods: {

onChange(value) {

console.log(value);

}

onEditorMounted(editor, monaco) {

window.editor = editor

window.monaco = monaco

},

}

};

复制代码

常用 api

editor.getValue()

获取编辑器中的所有文本,并生成一个字符串返回,会保留所有信息(换行、缩进、注释等等)。

editor.getSelection()

获取编辑器中被选中文案的 range ,返回一个对象,如下:

{

startLineNumber: 0,

startColumnNumber: 0,

endLineNumber: 0,

endColumnNumber: 0,

}

复制代码

editor.getModel()

获取编辑器当前的 textmodel,一般不会直接使用,通过 textmodel 可以对文本各种操作。

editor.getModel().findMatches(str|regexp)

功能和 “⌘ + F” 一致,通过字符串或正则表达式查找编辑器内匹配的文本,并返回匹配文本 range 的集合。

editor.getModel().getValueInRange(range)

通过 range 获取范围内的文本,返回一个字符串。

editor.getModel().getLinesContent(lineNumber)

如果传入 lineNumber,则返回对应行的文本字符串,不传参则返回所有行的文本字符串的集合。

editor.executeEdits()

在指定位置插入代码,跟 editor.setValue() 不同的地方是,可以用 “⌘ + Z” 撤销输入。

editor.executeEdits('insert-code', [

{

range: {

startLineNumber,

startColumn,

endLineNumber,

endColumn,

},

text,

},

])

复制代码

editor.addAction()

在右键菜单里增加一栏自定义的操作。

this.editor.addAction({

id: '', // 菜单项 id

label: '', // 菜单项名称

keybindings: [this.monaco.KeyMod.CtrlCmd | this.monaco.KeyCode.KEY_J], // 绑定快捷键

contextMenuGroupId: '9_cutcopypaste', // 所属菜单的分组

run: () => {}, // 点击后执行的操作

})

复制代码

monaco.editor.setModelMarkers()

在编辑器中用波浪线标出错误提示。

monaco.editor.setModelMarkers(editor.getModel(), 'owner', [

{

startLineNumber,

startColumn,

endLineNumber,

endColumn,

message, // 提示文案

severity: monaco.MarkerSeverity.Error, // 提示的类型

},

])

复制代码

招聘

微信支付招聘前后端开发,欢迎推荐,简历可发送到 timorliang@tencent.com ~

linux终端怎么设置monaco,Monaco Editor 使用指南相关推荐

  1. 将Linux终端语言设置为中文

    为了在终端更快地查阅man手册等,可以将终端语言设置为中文 命令: ①vim ~/.bashrc ,按i进入编辑模式 ②在文本最后添加export LANG="zh_CN.UTF-8&quo ...

  2. Linux终端中设置vi编辑命令

    前言 vi是个很好的编辑工具,可以快速定位文本,查找及修改问题,在Linux的终端中,我们输入命令时如果能集成vi可以更高效的实现命令的输入. 设置方法 在/etc/profile中追加:set -o ...

  3. Linux终端语系设置,iconv语系编码转换命令

    一.介绍 有时候在命令行输入命令后会显示乱码,其实是语系的不一样导致的:比如说在英语语序下不会显示中文 打印中文语系的日期 将中文语系改为英语语系 提示:设置语系只在本次命令行操作中生效,退出命令行后 ...

  4. Linux 终端terminal设置透明化

    为了方便查看终端的同时,又能查看终端遮挡的部分内容,设置终端terminal透明化,方便好用. 默认终端terminal是不透明的. 1,ubuntu系统: 打开一个terminal,点击 编辑选择 ...

  5. linux终端声音设置,终端命令设置音量?

    问题描述 我有一个外部声卡,大部分工作正常,除了第一次插入时或打开笔记本电脑时,音量设置为100%.也就是整个系统音量,如声音指示器所示. 我正在寻找的是一个终端命令,将该音量设置为50%,这样我就可 ...

  6. PS1设置(Linux终端开头设置)

    1.PS1是一个内置的shell变量. 2.颜色代码格式:\[\e[F;Bm\](F表示字体颜色,B表示背景颜色,具体如下) 字体代码 背景代码 颜色 30 40 黑色 31 41 红色 32 42 ...

  7. linux终端属性设置,如何重置终端属性和首选项?

    问题描述 我迷失了终端中的颜色和东西,现在想回到终端的栗色和白色默认配置.我必须删除哪些文件? 最佳解决方案 在终端中单击"编辑"菜单,然后单击"配置文件首选项" ...

  8. linux中如何设置群组路径,入门指南:管理Ubuntu用户和群组

    Ubuntu Linux用户群组可以帮你管理用户,为用户设置使用权限,甚至还可以设置用户使用电脑的时间.操作起来简单好用,一点也不比Windows差,最重要的呢肯花点时间去研究一下.本文将通过浅显易懂 ...

  9. Linux终端设置成256色模式

    vim的设置有多种作用域,可以是全局的,也就是该计算机所有登录用户都能用,也可以只给某个用户使用.我的系统是Linux Ubuntu 14.04,全局的配置文件目录在/etc下,本地的配置目录在~/. ...

最新文章

  1. APACHE 2.2.8+TOMCAT6.0.14配置负载均衡
  2. 初识tmux---编译安装tmux
  3. spark搭建和使用,处理massive文件
  4. c#字符串操作方法实例
  5. 信息学奥赛C++语言: 回文数个数
  6. topshelf和quartz内部分享
  7. kubenetes 1.4的Master节点克隆并改造为node节点以及node查询问题解决
  8. 团队-手机备忘录-需求分析
  9. 聚类算法论文研读 record
  10. iOS应用崩溃日志分析
  11. 关于 COPY 导入数据的问题
  12. 韩语零基础快速掌握韩语学习的小技…
  13. 加拿大 计算机硕士 哪个学校 便宜,加拿大计算机硕士成功案例1(学生成绩中)...
  14. C语言之指向一维数组的指针
  15. 学神经网络应该看看哪些书,神经网络相关书籍
  16. 论文阅读:Bi-Modal PMA
  17. (要更新)SRAM、DRAM、SDRAM、DDR异同
  18. android studio 出现: Design editor is unavailable until a successful build 问题的处理
  19. java enumeration 创建_Java Enumeration接口 - Java 教程 - 自强学堂
  20. html中box标签的作用,box-shadow属性的功能是什么

热门文章

  1. go结构体初始化_golang中结构体的初始化方法
  2. jsapi支付签名_微信支付JSAPI:商户签名错误
  3. C++ 传递字符串数组给函数参数
  4. 使用清华镜像安装pytorch失败的解决方法
  5. 网址的bibtex格式
  6. Redis系列一、redis介绍与安装
  7. echart 三维可视化地图_揭秘720°三维全景3D实景地图制作技术
  8. python中的set方法_Python中set与frozenset方法和区别详解
  9. Ios 12 linux,苹果发布iOS 12.4.1,以修补越狱漏洞
  10. BigDecimal的异常记录:java.lang.ArithmeticException: Rounding necessary