vue使用mavonEditor(流程图、时序图、甘特图实现)

mavonEditor

安装mavonEditor

复制代码
$ npm install mavon-editor --save

使用

复制代码
 // 全局注册
 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: '' }
     }
 })
 
//局部使用
import {mavonEditor} from 'mavon-editor'
import 'mavon-editor/dist/markdown/github-markdown.min.css'
import 'mavon-editor/dist/css/index.css'

template中使用mavonEditor
<div>
<mavonEditor
		ref="mavonEditorRef"
		v-model="markdownContent"
		:toolbars="toolbars"
		:externalLink="true"
		style="height: calc(100vh - 50px);z-index: 1;"
		@save="createWikiSave(0)"
		@imgAdd="addMarkdownImage"
		placeholder="请录入文档内容"
		class="page-content-editor wang-editor-body"/>
</div>

mavonEditor 使用markdownIt

搜索相关插件

markdownIt插件搜索

复制代码
https://www.npmjs.com/search?q=keywords:markdown-it-plugin%20mermaid
选择合适的插件
使用markdownIt 插件,实现流程图、时序图、甘特图

mermaid-it-markdown npm地址

mermaid-it-markdown语法地址

复制代码
//安装
npm install mermaid-it-markdown mermaid --save

//引用
import mermaidItMarkdown from 'mermaid-it-markdown'

//使用
const markdownIt = mavonEditor.getMarkdownIt()
markdownIt.use(mermaidItMarkdown)

报错记录

@liradb2000_markdown-it-mermaid.js?v=5c807a2b:2552 Error:
attribute width: A negative value is not valid. ("-33")

错误原因

mavonEditor使用@liradb2000/markdown-it-mermaid插件出现错误,编辑区域使用空格或者回车的时候,都会提示错误。

解决办法

更换插件,使用mermaid-it-markdown插件,实现流程图、时序图、甘特图

相关推荐
江城开朗的豌豆4 小时前
Vue组件CSS防污染指南:让你的样式乖乖“宅”在自家地盘!
前端·javascript·vue.js
江城开朗的豌豆4 小时前
Vue组件花式传值:祖孙组件如何愉快地聊天?
前端·javascript·vue.js
浩男孩5 小时前
【🍀新鲜出炉 】十个 “如何”从零搭建 Nuxt3 项目
前端·vue.js·nuxt.js
拉不动的猪6 小时前
pc和移动页面切换的两种基本方案对比
前端·javascript·vue.js
练习前端两年半6 小时前
揭秘Element Plus Button:从源码到架构的完整拆解
vue.js
Hilaku7 小时前
前端权限系统怎么做才不会写吐?我们项目踩过的 3 套失败方案总结
前端·javascript·vue.js
nbsaas-boot7 小时前
Vue 组件数据流与状态控制最佳实践规范
前端·javascript·vue.js
鹏多多.7 小时前
详解vue渲染函数render的使用
前端·javascript·vue.js·前端框架
初心w50t27 小时前
el-tree的属性render-content自定义样式不生效
前端·javascript·vue.js
网络点点滴7 小时前
什么是Vue.js
前端·javascript·vue.js