A markdown editor based on Vue
$ npm install mavon-editor --save
index.js
:
// Global Registration
// import with ES6
import Vue from 'vue'
import mavonEditor from 'mavon-editor'
import 'mavon-editor/dist/css/index.css'
// use
Vue.use(mavonEditor)
new Vue({
'el': '#main',
data() {
return { value: '' }
}
})
index.html
// The same below
<div id="main">
<mavon-editor v-model="value"/>
</div>
If you do not need code highlighting, you need set ishljs to false
Set ishljs = true
// default value is true
<mavon-editor :ishljs = "true"></mavon-editor>
For optimize the size of pack, since v2.4.2, the following files will default to using cdnjs
outside the chain:
highlight.js
github-markdown-css
katex
(v2.4.7)
The language parsing files and code highlighting in Code Highlighting highlight.js
will be loaded on demand.
github-markdown-css
and katex
will load only when mounted.
Notice: Option hljs color scheme and Supported language is export from highlight.js/9.12.0
<template>
<mavon-editor ref=md @imgAdd="$imgAdd" @imgDel="$imgDel"></mavon-editor>
</template>
exports default {
methods: {
// bind @imgAdd event
$imgAdd(pos, $file){
// step 1. upload image to server.
var formdata = new FormData();
formdata.append('image', $file);
axios({
url: 'server url',
method: 'post',
data: formdata,
headers: { 'Content-Type': 'multipart/form-data' },
}).then((url) => {
// step 2. replace url data:image/s3,"s3://crabby-images/f1016/f10166b2f498b31e73a53c8e018dc7560a9f7526" alt="..." -> data:image/s3,"s3://crabby-images/dc165/dc1650560f7b8931eb2f2bf7b54ecc566ca4d411" alt="..."
$vm.$img2Url(pos, url);
})
}
}
}
- Default size: min-height: 300px , min-width: 300px , Can be covered
- z-index: 1500
- Just for show html of md: toolbarsFlag: false , subfield: false, default_open: "preview"
name | type | default value | describe |
---|---|---|---|
value | String | Initial value | |
language | String | cn | Language switch, cn: Simplified Chinese , en: English , fr: French |
scrollStyle | Boolean | true | Open the scroll bar style(Temp only support chrome) |
subfield | Boolean | true | true: Double columns - Edit preview same screen , Single Columns - otherwise not |
default_open | String | edit: default show edit area , preview: default show preview area , other = edit | |
placeholder | String | Begin editing... | The default prompt text when the textarea is empty |
editable | Boolean | true | Edit switch |
code_style | String | code-github | markdown Style: default github, option hljs color scheme |
toolbarsFlag | Boolean | true | Show toolbars |
toolbars | Object | As in the following example | toolbars |
ishljs | Boolean | true | highlight code switch |
image_filter | Function | null | Image file filter Function, params is a File Object , you should return Boolean about the test result |
/*
The default toolbar properties are all true,
You can customize the object to cover them.
eg: {
bold: true,
italic: true,
header: true,
}
At this point, the toolbar only displays the three function keys.
*/
toolbars: {
bold: true,
italic: true,
header: true,
underline: true,
strikethrough: true,
mark: true,
superscript: true,
subscript: true,
quote: true,
ol: true,
ul: true,
link: true,
imagelink: true,
code: true,
table: true,
fullscreen: true,
readmodel: true,
htmlcode: true,
help: true,
/* 1.3.5 */
undo: true,
redo: true,
trash: true,
save: true,
/* 1.4.2 */
navigation: true,
/* 2.1.8 */
alignleft: true,
aligncenter: true,
alignright: true,
/* 2.2.1 */
subfield: true,
preview: true
}
name | params | describe |
---|---|---|
change | String: value , String: reder | Edit area change callback event (render: Html source code) |
save | String: value , String: reder | Ctrl+s and click save button |
fullscreen | Boolean: status , String: value | Fullscreen editing toggle callback event(boolean: Fullscreen status) |
readmodel | Boolean: status , String: value | Reading mode toggle callback event(boolean: Reading mode status) |
htmlcode | Boolean: status , String: value | Html code mode toggle callback event(boolean: status) |
subfieldtoggle | Boolean: status , String: value | Double columns edit mode toggle callback event(boolean: double columns status) |
previewtoggle | Boolean: status , String: value | Preview & Edit toggle callback event(boolean: preview status) |
helptoggle | Boolean: status , String: value | Help-me toggle callback event(boolean: help status) |
navigationtoggle | Boolean: status , String: value | Navigation mode toggle callback event(boolean: nav status) |
imgAdd | String: filename, File: imgfile | Add image file callback event(filename: write in origin md, File: File Object) |
imgDel | String: filename | Delete image file callback event(filename: write in origin md) |
mavonEditor is open source and released under the MIT Licence.
Copyright (c) 2017 hinesboy