前言
如果我们想在Web端实现在线代码编译的效果,那么需要使用组件vue-codemirror
,他是将CodeMirror
进行了再次封装
- 支持代码高亮
- 62种主题颜色,例如monokai等等
- 支持json, sql, javascript,css,xml, html,yaml, markdown, python编辑模式,默认为 json
- 支持快速搜索
- 支持自动补全提示
- 支持自动匹配括号
环境准备
npm install jshint
npm install jsonlint
npm install script-loader
npm install vue-codemirror
封装组件
我们可以在项目中的components
中将vue-codemirror
进行再次封装
<template>
<codemirror
ref="myCm"
v-model="editorValue"
:options="cmOptions"
@changes="onCmCodeChanges"
@blur="onCmBlur"
@keydown.native="onKeyDown"
@mousedown.native="onMouseDown"
@paste.native="OnPaste"
>
</codemirror>
</template>
<script>
import { codemirror } from "vue-codemirror";
import 'codemirror/keymap/sublime'
import "codemirror/mode/javascript/javascript.js";
import "codemirror/mode/xml/xml.js";
import "codemirror/mode/htmlmixed/htmlmixed.js";
import "codemirror/mode/css/css.js";
import "codemirror/mode/yaml/yaml.js";
import "codemirror/mode/sql/sql.js";
import "codemirror/mode/python/python.js";
import "codemirror/mode/markdown/markdown.js";
import "codemirror/addon/hint/show-hint.css";
import "codemirror/addon/hint/show-hint.js";
import "codemirror/addon/hint/javascript-hint.js";
import "codemirror/addon/hint/xml-hint.js";
import "codem