解决monaco-editor在vue中回显时没有宽高和自动格式化代码

解决monaco-editor在vue中回显时没有宽高

    // 初始化编辑器
    this.editor = Monaco.editor.create(code, {
      value: '',
      language: 'html',
      tabSize: 2,
      scrollBeyondLastLine: false,
      automaticLayout: true // 添加这行代码,表示自动布局
    });

手动触发action

比如说自动格式化代码,一般情况下都需要在代码编辑器右键菜单选择 format document来实现代码格式化。那么我们如何手动触发action呢?
方式一:
trigger的第一个参数没有实际意义,可以随便写,第二个参数表示actions的id,控制台打印this.editor,可以获取到所有action相关内容

triggerAction(id: string): void {
  if (!this.editor) return;
  this.editor.trigger("anything", id);
}

方式二:

triggerAction(id: string): void {
  if (!this.editor) return;
  this.editor.getAction([id])._run();
  // 或者this.editor.getAction([id]).run();
}

方式二只有在editor创建时 readOnly: false情况下生效

自动格式化

调用时机:取到数据,然后再调用方法
方式一:

this.editor.trigger("anything", "editor.action.formatDocument");

方式二:

this.editor.getAction(["editor.action.formatDocument"])._run();
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Monaco Editor是一个非常强大的代码编辑器,它支持自定义代码补全。下面是在Vue配置自定义代码补全的步骤: 1. 安装monaco-editormonaco-editor-webpack-plugin ``` npm install monaco-editor monaco-editor-webpack-plugin --save-dev ``` 2. 在vue.config.js添加配置: ``` const MonacoEditorPlugin = require('monaco-editor-webpack-plugin'); module.exports = { configureWebpack: { plugins: [ new MonacoEditorPlugin({ // 你的语言模型文件路径 languages: ['path/to/your/language-model'], }), ], }, }; ``` 3. 将monaco-editor组件添加到你的Vue组件: ``` <template> <div> <monaco-editor :language="language" :options="editorOptions" v-model="code" /> </div> </template> <script> import * as monaco from 'monaco-editor'; export default { name: 'MyComponent', data() { return { code: '', language: 'javascript', editorOptions: { // 自定义代码补全 suggestOnTriggerCharacters: true, suggest: { customProvider: (model, position) => { // 这里是你的代码补全逻辑 return { suggestions: [ { label: 'console.log', kind: monaco.languages.CompletionItemKind.Function, documentation: 'Log output to console', insertText: 'console.log(${1:object})', insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet, range: new monaco.Range(position.lineNumber, 1, position.lineNumber, position.column), }, ], }; }, }, }, }; }, }; </script> ``` 这里的suggest.customProvider是自定义代码补全的逻辑,你可以根据自己的需要进行改变。另外,你需要提供你的语言模型文件路径。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值