Security News
Bun 1.2 Released with 90% Node.js Compatibility and Built-in S3 Object Support
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
codemirror-editor-vue3
Advanced tools
The codemirror component of vue3. This component is developed based on Codemirror 5 and only vue3 is supported.
In addition to the officially supported modes, the log output presentation mode is added, out of the box, but not necessarily suitable for all scenarios.
For complete documentation and more cases, please check codemirror-editor-vue3 docs.
npm install codemirror-editor-vue3 codemirror@5.x -S
yarn add codemirror-editor-vue3 codemirror@5.x
pnpm i codemirror-editor-vue3 codemirror@^5.65.12 -S
If your project requires Typescript support, you will also need to install the '@types/codemirror' dependency.
npm install @types/codemirror -D
Do not recommend global registration components, which will result in the type of prompt on the template that cannot be properly obtained.
main.js:
import { createApp } from "vue";
import App from "./App.vue";
import { InstallCodemirro } from "codemirror-editor-vue3";
const app = createApp(App);
app.use(InstallCodemirro);
app.mount("#app");
The global registered component name is Codemirror or you can customize a component name, for example:
app.use(InstallCodemirro, { componentName: "customName" });
<template>
<Codemirror
v-model:value="code"
:options="cmOptions"
border
placeholder="test placeholder"
:height="200"
@change="change"
/>
</template>
<script>
import Codemirror from "codemirror-editor-vue3";
// placeholder
import "codemirror/addon/display/placeholder.js";
// language
import "codemirror/mode/javascript/javascript.js";
// placeholder
import "codemirror/addon/display/placeholder.js";
// theme
import "codemirror/theme/dracula.css";
import { ref } from "vue";
export default {
components: { Codemirror },
setup() {
const code = ref(`
var i = 0;
for (; i < 9; i++) {
console.log(i);
// more statements
}`);
return {
code,
cmOptions: {
mode: "text/javascript", // Language mode
theme: "dracula", // Theme
},
};
},
};
</script>
name | description | type | default |
---|---|---|---|
value(v-model) | Editor content | string | "" |
options | Configuration options of codemirror5 | EditorConfiguration | DEFAULT_OPTIONS |
placeholder | Editor placeholder content to introduce codemirror related files | string | "" |
border | Whether to display editor borders | boolean | false |
width | width | string | 100% |
height | height | string | 100% |
original-style | Using the original style, disable the second modification of the style for this component (but does not affect width, height, and border) | boolean | false |
KeepCursorInEnd | Always keep the mouse position on the last line | boolean | false |
merge | merge mode, can also be used as diff pattern | boolean | false |
name | Name, which is passed to the textarea inside the component(This is useless🙃) | string | - |
The following three are only the events encapsulated by this component. Please refer to more events Codemirror Events
event name | description | params |
---|---|---|
change | value or instance changes | (value: string, cm: Editor) => void |
input | input | (value: string) => void |
ready | The Codemirror component is mounted | (cm: Editor) => void; |
The following events are official events of Codemirror5. You can refer to the official documents for details Codemirror Event,You can use this component to bind events directly through components, for example:
<Codemirror
v-model:value="code"
:options="{ mode: 'text/x-vue', theme: 'default' }"
border
placeholder="test-placeholder"
:height="200"
@change="onChange"
@blur="onBlur"
@focus="onFocus"
@scroll="onScroll"
/>
All event names are as follows:
changes
scroll
beforeChange
cursorActivity
keyHandled
inputRead
electricInput
beforeSelectionChange
viewportChange
swapDoc
gutterClick
gutterContextMenu
focus
blur
refresh
optionChange
scrollCursorIntoView
update
2.3.0-beta2 (2023-03-07)
FAQs
CodeMirror component for Vue3
The npm package codemirror-editor-vue3 receives a total of 5,684 weekly downloads. As such, codemirror-editor-vue3 popularity was classified as popular.
We found that codemirror-editor-vue3 demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.