Vue3中使用Monaco Editor代码编辑器记录——主动触发代码补全功能~持续更新
近期因为毕设的原因,需要使用代码编辑器,我采用monaco-editor代码编辑器
前端框架使用Vue3
+ elementUI
monaco-editor
插件版本@0.30.1
monaco-editor-webpack-plugin
插件版本@6.0.0
若还没有安装插件,具体安装步骤和一些基础使用可以查看上一篇Vue3中使用Monaco Editor代码编辑器记录~持续更新
主动触发代码补全Completion
此处以python
和sql
自动补全为例进行说明
1. registerCompletionItemProvider函数
monaco-editor提供了代码自动补全的函数registerCompletionItemProvider
,其参数如下。可以看到有两个参数,分别是languageId
和provider
export function registerCompletionItemProvider(languageId: string, provider: CompletionItemProvider): IDisposable;
具体使用:
monaco.languages.registerCompletionItemProvider('python', {
// provideCompletionItems有四个参数model、position、context、token,可根据需要使用
provideCompletionItems: function (model, position, context, token) {
// ......
},
});
2. 踩坑
一开始,我百度之后是这样写的:
// 创建python代码提醒
monaco.languages.registerCompletionItemProvider('python', {
provideCompletionItems: function () {
// ......
},
triggerCharacters: [':', 'F', 'i']