linux终端怎么设置monaco,Monaco Editor 使用指南
为什么要写这篇文章?
最近开发了一个简单的在线代码编辑器,基于 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 使用指南相关推荐
- 将Linux终端语言设置为中文
为了在终端更快地查阅man手册等,可以将终端语言设置为中文 命令: ①vim ~/.bashrc ,按i进入编辑模式 ②在文本最后添加export LANG="zh_CN.UTF-8&quo ...
- Linux终端中设置vi编辑命令
前言 vi是个很好的编辑工具,可以快速定位文本,查找及修改问题,在Linux的终端中,我们输入命令时如果能集成vi可以更高效的实现命令的输入. 设置方法 在/etc/profile中追加:set -o ...
- Linux终端语系设置,iconv语系编码转换命令
一.介绍 有时候在命令行输入命令后会显示乱码,其实是语系的不一样导致的:比如说在英语语序下不会显示中文 打印中文语系的日期 将中文语系改为英语语系 提示:设置语系只在本次命令行操作中生效,退出命令行后 ...
- Linux 终端terminal设置透明化
为了方便查看终端的同时,又能查看终端遮挡的部分内容,设置终端terminal透明化,方便好用. 默认终端terminal是不透明的. 1,ubuntu系统: 打开一个terminal,点击 编辑选择 ...
- linux终端声音设置,终端命令设置音量?
问题描述 我有一个外部声卡,大部分工作正常,除了第一次插入时或打开笔记本电脑时,音量设置为100%.也就是整个系统音量,如声音指示器所示. 我正在寻找的是一个终端命令,将该音量设置为50%,这样我就可 ...
- PS1设置(Linux终端开头设置)
1.PS1是一个内置的shell变量. 2.颜色代码格式:\[\e[F;Bm\](F表示字体颜色,B表示背景颜色,具体如下) 字体代码 背景代码 颜色 30 40 黑色 31 41 红色 32 42 ...
- linux终端属性设置,如何重置终端属性和首选项?
问题描述 我迷失了终端中的颜色和东西,现在想回到终端的栗色和白色默认配置.我必须删除哪些文件? 最佳解决方案 在终端中单击"编辑"菜单,然后单击"配置文件首选项" ...
- linux中如何设置群组路径,入门指南:管理Ubuntu用户和群组
Ubuntu Linux用户群组可以帮你管理用户,为用户设置使用权限,甚至还可以设置用户使用电脑的时间.操作起来简单好用,一点也不比Windows差,最重要的呢肯花点时间去研究一下.本文将通过浅显易懂 ...
- Linux终端设置成256色模式
vim的设置有多种作用域,可以是全局的,也就是该计算机所有登录用户都能用,也可以只给某个用户使用.我的系统是Linux Ubuntu 14.04,全局的配置文件目录在/etc下,本地的配置目录在~/. ...
最新文章
- APACHE 2.2.8+TOMCAT6.0.14配置负载均衡
- 初识tmux---编译安装tmux
- spark搭建和使用,处理massive文件
- c#字符串操作方法实例
- 信息学奥赛C++语言: 回文数个数
- topshelf和quartz内部分享
- kubenetes 1.4的Master节点克隆并改造为node节点以及node查询问题解决
- 团队-手机备忘录-需求分析
- 聚类算法论文研读 record
- iOS应用崩溃日志分析
- 关于 COPY 导入数据的问题
- 韩语零基础快速掌握韩语学习的小技…
- 加拿大 计算机硕士 哪个学校 便宜,加拿大计算机硕士成功案例1(学生成绩中)...
- C语言之指向一维数组的指针
- 学神经网络应该看看哪些书,神经网络相关书籍
- 论文阅读:Bi-Modal PMA
- (要更新)SRAM、DRAM、SDRAM、DDR异同
- android studio 出现: Design editor is unavailable until a successful build 问题的处理
- java enumeration 创建_Java Enumeration接口 - Java 教程 - 自强学堂
- html中box标签的作用,box-shadow属性的功能是什么
热门文章
- go结构体初始化_golang中结构体的初始化方法
- jsapi支付签名_微信支付JSAPI:商户签名错误
- C++ 传递字符串数组给函数参数
- 使用清华镜像安装pytorch失败的解决方法
- 网址的bibtex格式
- Redis系列一、redis介绍与安装
- echart 三维可视化地图_揭秘720°三维全景3D实景地图制作技术
- python中的set方法_Python中set与frozenset方法和区别详解
- Ios 12 linux,苹果发布iOS 12.4.1,以修补越狱漏洞
- BigDecimal的异常记录:java.lang.ArithmeticException: Rounding necessary