v-markdown-editor is a simple Markdown editor component for Vue wrapper codemirror
npm install v-markdown-editor
import 'v-markdown-editor/dist/v-markdown-editor.css';
import Vue from 'vue'
import Editor from 'v-markdown-editor'
// global register
Vue.use(Editor);
<link href="https://cdn.jsdelivr.net/npm/v-markdown-editor/dist/v-markdown-editor.css" rel="stylesheet">
<script src="https://cdn.jsdelivr.net/npm/v-markdown-editor/dist/v-markdown-editor.min.js" type="text/javascript"></script>
<link href="https://unpkg.com/v-markdown-editor/dist/v-markdown-editor.css" rel="stylesheet">
<script src="https://unpkg.com/v-markdown-editor/dist/v-markdown-editor.min.js" type="text/javascript"></script>
1.2.0
- Support Fontawsome & Material Design Icons
- Remove jQuery
<template>
<div class="container">
<markdown-editor :options="options"></markdown-editor>
</div>
</template>
<script>
export default {
data() {
return {
// default options, see more options at: http://codemirror.net/doc/manual.html#config
options: {
// lineNumbers: true,
// styleActiveLine: true,
// styleSelectedText: true,
// lineWrapping: true,
// indentWithTabs: true,
// tabSize: 2,
// indentUnit: 2
}
}
}
}
</script>
<template>
<div class="container">
<markdown-editor v-model="value"></markdown-editor>
</div>
</template>
<script>
export default {
data() {
return {
value: 'Hello world!'
}
}
}
</script>
// full toolbar: clean redo undo | bold italic strikethrough heading | image link | numlist bullist code quote | preview fullscreen
<template>
<div class="container">
<markdown-editor toolbar="bold italic heading | image link | numlist bullist code quote | preview fullscreen"></markdown-editor>
</div>
</template>
<template>
<div class="container">
<markdown-editor toolbar="bold italic upload" @command:upload="upload" :extend="custom"></markdown-editor>
</div>
</template>
<script>
export default {
data() {
return {
custom: {
'upload': {
cmd: 'upload',
ico: 'fas fa-upload',
title: 'Upload File'
}
}
}
},
methods:{
upload(md){
md.drawImage({url:'https://i.imgur.com/CbCXhBe.png', title:'this image title'});
}
}
}
</script>
<template>
<div class="container">
<markdown-editor ref="md"></markdown-editor>
<button @click="replace" class="btn btn-primary">Handle</button>
</div>
</template>
<script>
export default {
methods: {
replace(){
// more info: https://codemirror.net/doc/manual.html#api
this.$refs.md.editor.replaceSelection("Handle editor");
}
},
}
</script>
<markdown-editor @change="onChange"></markdown-editor>
<script>
export default {
methods: {
onChange(val){
console.log(val);
}
},
}
</script>
<markdown-editor height="auto"></markdown-editor>
<markdown-editor theme="primary"></markdown-editor>
#vuejs #javascript #vue-js