Vue:Vue-cli2结合mavonEditor实现MarkDown编辑器

1. 安装

  • npm install mavon-editor --save

2. 注册

在main.js中进行引入注册

// 全局注册
// 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: '' }
    }
})

3. 基础使用

在组件中,直接通过<mavon-editor/>标签进行使用

<template>
  <div id="MarkDown">
    <mavon-editor v-model="value"/>
  </div>
</template>

<script>
export default {
  name: "MarkDown",
  data() {
    return {
      value:123
    }
  }
}
</script>

<style lang="scss" scoped>
#MarkDown {
  height: 100%;
  width: 100%;
  background-color: blue;
}
</style>

效果:
在这里插入图片描述

4. API

props

name 名称type 类型default 默认值describe 描述
valueString初始值
languageStringzh-CN语言选择,暂支持 zh-CN: 简体中文, zh-TW: 正体中文 , en: 英文 , fr: 法语, pt-BR: 葡萄牙语, ru: 俄语, de: 德语, ja: 日语
fontSizeString14px编辑区域文字大小
scrollStyleBooleantrue开启滚动条样式(暂时仅支持chrome)
boxShadowBooleantrue开启边框阴影
boxShadowStyleString0 2px 12px 0 rgba(0, 0, 0, 0.1)边框阴影样式
transitionBooleantrue是否开启过渡动画
toolbarsBackgroundString#ffffff工具栏背景颜色
previewBackgroundString#fbfbfb预览框背景颜色
subfieldBooleantruetrue: 双栏(编辑预览同屏), false: 单栏(编辑预览分屏)
defaultOpenStringedit: 默认展示编辑区域 , preview: 默认展示预览区域 , 其他 = edit
placeholderString开始编辑…输入框为空时默认提示文本
editableBooleantrue是否允许编辑
codeStyleStringcode-githubmarkdown样式: 默认github, 可选配色方案
toolbarsFlagBooleantrue工具栏是否显示
navigationBooleanfalse默认展示目录
shortCutBooleantrue是否启用快捷键
autofocusBooleantrue自动聚焦到文本框
ishljsBooleantrue代码高亮
imageFilterfunctionnull图片过滤函数,参数为一个File Object,要求返回一个Boolean, true表示文件合法,false表示文件不合法
imageClickfunctionnull图片点击事件,默认为预览,可覆盖
tabSizeNumber\ttab转化为几个空格,默认为\t
xssOptionsObjectnullxss规则配置,参考
toolbarsObject如下例工具栏
/*
    默认工具栏按钮全部开启, 传入自定义对象
    例如: {
         bold: true, // 粗体
         italic: true,// 斜体
         header: true,// 标题
    }
    此时, 仅仅显示此三个功能键
 */
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, // code
   table: true, // 表格
   fullscreen: true, // 全屏编辑
   readmodel: true, // 沉浸式阅读
   htmlcode: true, // 展示html源码
   help: true, // 帮助
   /* 1.3.5 */
   undo: true, // 上一步
   redo: true, // 下一步
   trash: true, // 清空
   save: true, // 保存(触发events中的save事件)
   /* 1.4.2 */
   navigation: true, // 导航目录
   /* 2.1.8 */
   alignleft: true, // 左对齐
   aligncenter: true, // 居中
   alignright: true, // 右对齐
   /* 2.2.1 */
   subfield: true, // 单双栏模式
   preview: true, // 预览
}

events 事件绑定

name 方法名params 参数describe 描述
changeString: value , String: render编辑区发生变化的回调事件(render: value 经过markdown解析后的结果)
saveString: value , String: renderctrl + s 的回调事件(保存按键,同样触发该回调)
fullScreenBoolean: status , String: value切换全屏编辑的回调事件(boolean: 全屏开启状态)
readModelBoolean: status , String: value切换沉浸式阅读的回调事件(boolean: 阅读开启状态)
htmlCodeBoolean: status , String: value查看html源码的回调事件(boolean: 源码开启状态)
subfieldToggleBoolean: status , String: value切换单双栏编辑的回调事件(boolean: 双栏开启状态)
previewToggleBoolean: status , String: value切换预览编辑的回调事件(boolean: 预览开启状态)
helpToggleBoolean: status , String: value查看帮助的回调事件(boolean: 帮助开启状态)
navigationToggleBoolean: status , String: value切换导航目录的回调事件(boolean: 导航开启状态)
imgAddString: filename, File: imgfile图片文件添加回调事件(filename: 写在md中的文件名, File: File Object)
imgDelString: filename图片文件删除回调事件(filename: 写在md中的文件名)

5. 代码高亮

  1. 安装highlight.js
    npm install highlight.js

  2. main.js中引入并注册全局指令

    // 引入高亮
    import hljs from 'highlight.js'
    import 'highlight.js/styles/googlecode.css'
    // 注册指令
    Vue.directive('highlight', function (el) {
        let blocks = el.querySelectorAll('pre code')
        blocks.forEach((block) => {
            hljs.highlightBlock(block)
        })
    })
    

    在这里插入图片描述

  3. 组件中引入css

    import 'mavon-editor/dist/markdown/github-markdown.min.css'
    

    在这里插入图片描述

  4. 使用指令即可
    在这里插入图片描述

6. 完整组件代码

<template>
  <div id="MarkDown" v-highlight>
    <mavon-editor
        id="md"
        v-model="value" :fontSize="fontSize" :scrollStyle="scrollStyle"
        :placeholder="placeholder"
        :codeStyle="codeStyle" :ishljs="ishljs" :toolbars="toolbars"
        @save="saveImpl" @imgAdd="imgAddImpl" @imgDel="imgDelImpl"
    />
  </div>
</template>

<script>
import 'mavon-editor/dist/markdown/github-markdown.min.css'
import {textService,demo} from "@/service/api";

const 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, // code
  table: true, // 表格
  fullscreen: false, // 全屏编辑
  readmodel: false, // 沉浸式阅读
  htmlcode: false, // 展示html源码
  help: true, // 帮助
  /* 1.3.5 */
  undo: true, // 上一步
  redo: true, // 下一步
  trash: true, // 清空
  save: true, // 保存(触发events中的save事件)
  /* 1.4.2 */
  navigation: true, // 导航目录
  /* 2.1.8 */
  alignleft: true, // 左对齐
  aligncenter: true, // 居中
  alignright: true, // 右对齐
  /* 2.2.1 */
  subfield: true, // 单双栏模式
  preview: false, // 预览
}

export default {
  name: "MarkDown",
  props: {
    editorContent: {type: String, default: null},
    fontSize: {type: String, default: `18px`},
    scrollStyle: {type: Boolean, default: true},
    placeholder: {type: String, default: `请输入内容`},
    ishljs: {type: Boolean, default: true},
    codeStyle: {type: String, default: "tomorrow-night-eighties"},
  },
  data() {
    return {
      toolbars: toolbars,
      editText: ""
    }
  },
  methods: {
    /**
     * ctrl + s 的回调事件(保存按键,同样触发该回调)
     * @param value
     * @param render
     */
    saveImpl(value, render) {
      textService().then(res => {
        console.log(res);
      })
    },
    /**
     * 图片文件添加回调事件(filename: 写在md中的文件名, File: File Object)
     * @param filename
     * @param imgFile
     */
    imgAddImpl(filename, imgFile) {
      const formdata = new FormData();
      formdata.append('image', imgFile);
      demo(formdata).then(res => {
        console.log(res);
      })
    },
    /**
     * 图片文件删除回调事件(filename: 写在md中的文件名)
     * @param filename
     */
    imgDelImpl(filename) {

    }
  },
  computed: {
    value: {
      get: function () {
        return this.editorContent
      },
      // setter
      set: function (newValue) {
        this.editText = newValue
      }
    }
  }
}
</script>

<style lang="scss" scoped>
#MarkDown {
  height: 100%;
  width: 100%;
  position: relative;

  #md {
    height: 100%;
    width: 100%;
  }
}
</style>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

KaiSarH

如果觉得文章不错,可以支持下~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值