Uh oh!
There was an error while loading.Please reload this page.
- Notifications
You must be signed in to change notification settings - Fork381
@codemirror code editor component for@vuejs
License
surmon-china/vue-codemirror
Folders and files
| Name | Name | Last commit message | Last commit date | |
|---|---|---|---|---|
Repository files navigation
CodeMirror(6) component forVue(3).
vue-codemirror v5/v6 has been released. This is a new version based onCodeMirror@6 and is available to Vue3 only. Since CodeMirror@6 is developed with native ES Modules, the new version will no longer support direct browser references to UMD modules. In short, the new version is
Thisexample site contains most of what you want.
- examples (Vue2)
- vue-codemirror@4.x (Vue2 / CodeMirror5)
- CodeMirror6 Guide
- CodeMirror6 APIs
- CodeMirror6 Examples
- CodeMirror6 Example: Writing a Language Package
- CodeMirror6 Example: Styling
- CodeMirror Forum
yarn add codemirror vue-codemirror
npm install codemirror vue-codemirror --save
# CodeMirror languages...yarn add @codemirror/lang-htmlyarn add @codemirror/lang-jsonyarn add @codemirror/lang-javascript# CodeMirror themes...yarn add @codemirror/theme-one-dark# more CodeMirror packages...
If you need import API/interface from codemirror, you need to make codemirror explicitly dependent in yourpackage.json
e.g.
"dependencies": {"@codemirror/state":"6.x"}
import{EditorState}from'@codemirror/state'
<template> <codemirrorv-model="code"placeholder="Code goes here...":style="{ height: '400px' }":autofocus="true":indent-with-tab="true":tab-size="2":extensions="extensions"@ready="handleReady"@change="log('change', $event)"@focus="log('focus', $event)"@blur="log('blur', $event)" /></template><script>import {defineComponent,ref,shallowRef }from'vue'import {Codemirror }from'vue-codemirror'import {javascript }from'@codemirror/lang-javascript'import {oneDark }from'@codemirror/theme-one-dark'exportdefaultdefineComponent({ components: { Codemirror },setup() {constcode=ref(`console.log('Hello, world!')`)constextensions= [javascript(), oneDark]// Codemirror EditorView instance refconstview=shallowRef()consthandleReady= (payload)=> {view.value=payload.view }// Status is available at all times via Codemirror EditorViewconstgetCodemirrorStates= ()=> {conststate=view.value.stateconstranges=state.selection.rangesconstselected=ranges.reduce((r,range)=> r+range.to-range.from,0)constcursor= ranges[0].anchorconstlength=state.doc.lengthconstlines=state.doc.lines// more state info ...// return ... }return { code, extensions, handleReady, log:console.log } } })</script>
import{createApp}from'vue'import{basicSetup}from'codemirror'importVueCodemirrorfrom'vue-codemirror'constapp=createApp()app.use(VueCodemirror,{// optional default global optionsautofocus:true,disabled:false,indentWithTab:true,tabSize:2,placeholder:'Code goes here...',extensions:[basicSetup]// ...})
| prop | description | type | default |
|---|---|---|---|
| modelValue | The input values accepted by the component also support two-way binding. | String | '' |
| autofocus | Focus editor immediately after mounted. | Boolean | false |
| disabled | Disable input behavior and disable change state. | Boolean | false |
| indentWithTab | Bind keyboard Tab key event. | Boolean | true |
| tabSize | Specify the indent when the Tab key is pressed. | Number | 2 |
| placeholder | Display when empty. | String | '' |
| style | The CSS style object that acts on the CodeMirror itself. | Object | {} |
| phrases | Codemirrorinternationalization phrases. | Object | {} |
| autoDestroy | Auto destroy the CodeMirror instance before the component unmount. | Boolean | true |
| extensions | Passed to CodeMirrorEditorState.create({ extensions }) | Extension | [] |
| selection | Passed to CodeMirrorEditorState.create({ selection }) | EditorSelection | - |
| root | Passed to CodeMirrornew EditorView({ root }) | ShadowRoot | Document | - |
| event | description | params |
|---|---|---|
update:modelValue | Only when the CodeMirror content (doc) has changed. | (value: string, viewUpdate: ViewUpdate) |
| change | ditto | ditto |
| update | When any state of CodeMirror changes. | (viewUpdate: ViewUpdate) |
| focus | When CodeMirror focused. | (viewUpdate: ViewUpdate) |
| blur | When CodeMirror blurred. | (viewUpdate: ViewUpdate) |
| ready | When editor component mounted. | (payload: { view: EditorView; state: EditorState; container: HTMLDivElement }) |
Thebasic-setup extension is integrated by default in the vue-codemirror configuration and is intended as a handy helper to quickly set up CodeMirror without having to install and import a lot of standalone packages. If you want to override the default behavior of the config, just pass the empty array when installing the component globally.
app.use(VueCodemirror,{// keep the global default extensions emptyextensions:[]})
Detailed changes for each release are documented in therelease notes.
Licensed under theMIT License.
About
@codemirror code editor component for@vuejs
Topics
Resources
License
Uh oh!
There was an error while loading.Please reload this page.
Stars
Watchers
Forks
Sponsor this project
Uh oh!
There was an error while loading.Please reload this page.
Contributors15
Uh oh!
There was an error while loading.Please reload this page.