ace editor component by vue
- VueSplitEditor: split one or more editor;
- VueStaticHighlight: Simply highlighting multiple languages;
- VueAceEditor: Customizable Code Tips;
npm install --save vue2x-ace-editor
- default
import Editor from 'vue2x-ace-editor';
export default {
...
components:{
Editor
}
...
}
- on demand
import {VueAceEditor,VueSplitEditor,VueStaticHighlight} from 'vue2x-ace-editor';
export default {
...
components:{
VueAceEditor,
VueSplitEditor,
VueStaticHighlight
}
...
}
Note: When introducing resources, it is better to introduce them in a static way and in a dynamic way. When packaging, webpack will replace the variables in the URL with regular. * and then pack the irrelevant files. (e.g.'import ('brace/ext/'+var), all the files below the EXT file will be packaged. )
- introduce globally
import ace from 'brace'
import 'brace/ext/language_tools';
import 'brace/mode/python'
import 'brace/snippets/python';
import 'brace/theme/eclipse';
- introduce initially
methods: {
editorInit() {
require("brace/ext/language_tools");
require("brace/mode/python");
require("brace/snippets/python");
require("brace/theme/eclipse");
}
}
- VueAceEditor
<editor
height="300px"
ref="editor"
:content="content"
:options="{
enableBasicAutocompletion: true,
enableSnippets: true,
enableLiveAutocompletion: true,
tabSize:2
}"
:fontSize='14'
:lang="'python'"
:theme="'eclipse'"
@onChange="editorChange"
@init="editorInit">
<div>toolbar or something</div>
</editor>
- VueSplitEditor
<vue-split-editor
ref="editor"
lang="python"
theme="monokai"
height="330px"
:splits="2"
:options="{
enableBasicAutocompletion: true,
enableSnippets: true,
enableLiveAutocompletion: true,
tabSize: 2
}"
:content="content2"
orientation="below"
></vue-split-editor>
- VueStaticHighlight
<vue-static-highlight
content="balabala"
theme="chrome"
lang="text"
@init="init">
<div>toolbar or something</div>
</vue-static-highlight>