vue 項目中使用 markdown編輯器 mavon-editor

vue version: vue 2.5.*css

安裝 github地址

npm install mavon-editor --save

引入

引入有多種方式,可是我常使用的是以組件的形式來引入html

<template>
    <div>
      <mavon-editor ref="editor" v-model="doc"> </mavon-editor>
    </div>
</template>
<script>
import {mavonEditor} from "mavon-editor";
import "mavon-editor/dist/css/index.css";
export default {
    name: "Create",
    components: {mavonEditor},
    data(){
      return {
        doc: '',
      }
    }
}
</script>

獲取/修改值

使用 $refsvue

// 獲取 markdown
let markdown = this.$refs.editor.d_value;
// 修改 markdown
this.$refs.editor.d_value = '> hello world';

// 獲取編譯後的 html
let html = this.$refs.editor.d_render;

使用 v-modelgit

// 獲取 markdown
let doc = this.doc;
// 修改  markdown
this.doc = 'hello world';
  • 注: 使用 $refs 的方式獲取值能夠獲取到 markdown 和 編譯後的 html, 可是使用 v-model 只能獲取到 markdown

文檔

可用props
可用事件
圖片處理github

可能有用

7942449-90070d37084764ef.png
events
  • 利用一個例子看params的使用方式params的使用方式
<template>
    <div>
        <!-- 
            @save: 按下 ctrl + s 時觸發
            @change: 當值發生改變時 觸發
        -->
        <mavon-editor
            @save="saveDoc"
            @change="updateDoc"
            ref="editor"
            v-model="doc">
         </mavon-editor>
    </div>
</template>
<script>
import { mavonEditor } from "mavon-editor";
import "mavon-editor/dist/css/index.css";
export default {
    name: "Create",
    components: { mavonEditor },
    data() {
        return {
            doc: ""
        };
    },
    methods: {
        updateDoc(markdown, html) {
            // 此時會自動將 markdown 和 html 傳遞到這個方法中
            console.log("markdown內容: " + markdown);
            console.log("html內容:" + markdown);
        },
        saveDoc(markdown, html) {
            // 此時會自動將 markdown 和 html 傳遞到這個方法中
            console.log("markdown內容:" + markdown);
            console.log("html內容:" + html);
        }
    }
};
</script>
相關文章
相關標籤/搜索