vue-element(五)高亮编辑器(Monaco)组件

参考

Vue项目中使用高亮编辑器(Monaco): https://blog.csdn.net/breavo_raw/article/details/88080451

一、monaco安装和插件配置

安装monaco

npm install monaco-editor -S

安装monaco-editor-webpack-plugin

npm install monaco-editor-webpack-plugin -S

配置monaco-editor-webpack-plugin插件
build/webpack.base.conf.js中新增如下配置

const MonacoWebpackPlugin = require('monaco-editor-webpack-plugin')
module.exports = {
  plugins: [
    new MonacoWebpackPlugin()
  ]
}

二、组件化

1.template

<template>
  <div ref="editorContainer" class="editor-container">
    <div ref="editor" class="monaco-editor"></div>
  </div>
</template>
  1. script
  • 引入monacoelement-resize-detector
// 高亮编辑器
import * as monaco from 'monaco-editor'
// 监控组件尺寸变化
// 安装: npm install element-resize-detector --save
import elementResizeDetectorMaker from 'element-resize-detector'
  • 组件参数定义
export default {
  props: {
    value: String, // 需要高亮的代码
    language: String, // 语言类型
    readOnly: Boolean // 是否自读,true:自读,不可修改;false:可以修改
  },
  data () {
    return {
      languages: ['apex', 'azcli', 'bat', 'clojure', 'coffee', 'cpp', 'csharp', 'csp', 'css', 'dockerfile', 'fsharp', 'go', 'handlebars', 'html', 'ini', 'java', 'javascript', 'json', 'less', 'lua', 'markdown', 'msdax', 'mysql', 'objective', 'perl', 'pgsql', 'php', 'postiats', 'powerquery', 'powershell', 'pug', 'python', 'r', 'razor', 'redis', 'redshift', 'ruby', 'rust', 'sb', 'scheme', 'scss', 'shell', 'solidity', 'sql', 'st', 'swift', 'typescript', 'vb', 'xml', 'yaml'],
      themes: ['vs', 'hc-black', 'vs-dark'], 
      theme: 'vs-dark', // 编辑器风格
      editorOptions: {
        selectOnLineNumbers: true,
        roundedSelection: false,
        readOnly: this.readOnly, // 只读
        cursorStyle: 'line', // 光标样式
        automaticLayout: false, // 自动布局
        glyphMargin: true, // 字形边缘
        useTabStops: false,
        fontSize: 28, // 字体大小
        autoIndent: false // 自动布局
      }
    }
  }
}
  • 新建初始化方法
methods: {
  initEditor () {
      let self = this
      self.$refs.editor.innerHTML = ''
      self.monacoEditor = monaco.editor.create(self.$refs.editor, {
        value: self.currentValue,
        language: self.language,
        theme: self.theme, // vs, hc-black, or vs-dark
        readOnly: self.readOnly,
        editorOptions: self.editorOptions
      })
      self.$emit('onMounted', self.monacoEditor)// 编辑器创建完成回调
      self.monacoEditor.onDidChangeModelContent(function (event) { // 编辑器内容changge事件
        self.currentValue = self.monacoEditor.getValue()
        self.$emit('onCodeChange', self.monacoEditor.getValue(), event)
      })
      // 自定义键盘事件
      self.monacoEditor.addCommand(monaco.KeyMod.CtrlCmd | monaco.KeyCode.KEY_S, function () {
        self.$emit('onCommit', self.monacoEditor.getValue(), self.monacoEditor)
      })
      self.monacoEditor.addCommand(monaco.KeyMod.CtrlCmd | monaco.KeyMod.Alt | monaco.KeyCode.KEY_S, function () {
        // 自定义快捷操作
      })
    }
}
  • 数据双向绑定
  computed: {
    // v-model 实现数据双向绑定
    currentValue: {
      get: function () {
        return this.value
      },
      set: function (value) {
        this.$emit('input', value)
      }
    }
  }
  • 挂载时初始化以及父元素尺寸监控
  mounted () {
    this.initEditor()
    let erd = elementResizeDetectorMaker()
    let that = this
    erd.listenTo(that.$refs.editorContainer, function (el) {
      that.$nextTick(function () {
        // 使echarts尺寸重置
        that.initEditor()
      })
    })
  }
  • 设置配置修改的方法
methods: {
    changeLanguage (val) {
      monaco.editor.setModelLanguage(this.monacoEditor.getModel(), val)
    },
    changeTheme (val) {
      monaco.editor.setTheme(val)
    },
    changeOptions () {
      // 修改配置
      this.monacoEditor.updateOptions(this.editorOptions)
    }
}
  • 样式设置,尺寸跟随父元素变化
  .editor-container {
    height: 100%;
    position: relative;
  }
  .monaco-editor{
    height: 100%;
    position: relative;
  }

三、使用

<template>
  <div class="my-editor">
    <wb-editor v-model="value" language="python"></wb-editor>
  </div>
</template>
import WbEditor from '@/components/wbEditor'
export default {
  name: 'index',
  components: {WbEditor},
  data () {
    return {
      value: 'map(lambda x, y: x + y, [1, 3, 5, 7, 9], [2, 4, 6, 8, 10])'
    }
  }
}

四、效果

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352

推荐阅读更多精彩内容