Vue3 前端 引入 markmap 思维导图,通过markdown解析成思维导图

 安装

// 
npm install markmap-lib

//
npm install markmap-view

//
npm install markmap-common

 完整代码

<script setup>
import { ref, onMounted, onUpdated } from 'vue'
import { Transformer } from 'markmap-lib'
import { Markmap } from 'markmap-view'
import * as htmlToImage from 'html-to-image'
import { saveAs } from 'file-saver'

const transformer = new Transformer()

const initValue = `
# 思维导图

1. 标题1
 - 子标题1
 - 子标题2
3. 标题2
4. 标题3
- beautiful
- useful
- easy
- interactive
`

const mm = ref()
const svgRef = ref()

const update = () => {
  const { root } = transformer.transform(initValue)
  mm.value.setData(root)
  mm.value.fit()
}

const zoomIn = () => mm.value.rescale(1.25)

const zoomOut = () => mm.value.rescale(0.8)

const fitToScreen = () => mm.value.fit()

const onSave = async () => {
  const dataUrl = await htmlToImage.toPng(svgRef.value)

  saveAs(dataUrl, 'markmap.png')
}

onMounted(() => {
  // 初始化markmap思维导图
  mm.value = Markmap.create(svgRef.value)
  // 更新思维导图渲染
  update()
})

onUpdated(update)
</script>

<template>
  <div class="mind">
    <div class="svg-container">
      <svg ref="svgRef"></svg>
    </div>
    <div class="controls">
      <button @click="zoomIn">放大</button>
      <button @click="zoomOut">缩小</button>
      <button @click="fitToScreen">适应屏幕</button>
      <button @click="onSave">下载</button>
    </div>
  </div>
</template>

<style lang="scss" scoped>
.mind {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  .svg-container {
    flex: 1;
    svg {
      width: 100%;
      height: 100%;
    }
  }
  .controls {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 50px;
  }
}

.controls {
  margin-top: 10px;
}
</style>

要使用Vue 3和AntV来实现思维导图,可以按照以下步骤进行操作: 1. 安装Vue 3和AntV:在项目目录下运行命令`npm install vue@next @antv/g6`来安装Vue 3和AntV G6图表库。 2. 创建Vue组件:在Vue项目中创建一个新的组件,命名为"MindMap"。在组件中导入Vue和AntV G6。 3. 初始化G6图表:在组件的生命周期钩子函数`mounted`中,使用AntV G6的`Graph`类初始化一个图表实例,并将其绑定到Vue组件实例的数据属性中。 4. 定义思维导图数据:在Vue组件中定义一个数据属性,用于存储思维导图的节点和边的数据。 5. 绘制思维导图:在Vue组件的`mounted`生命周期钩子函数中,使用G6图表实例的`data`方法将思维导图的数据绑定到图表上,并使用G6图表实例的`render`方法绘制图表。 6. 添加交互能力:通过G6图表实例的事件监听和交互能力,为思维导图添加节点的拖拽、缩放、连线等交互操作。 7. 样式定制和主题设置:通过G6图表实例的配置项,可以定制思维导图的样式和主题,如节点的颜色、形状、连线的样式等。 8. 完善其他功能:根据实际需求,可以实现添加节点、删除节点、编辑节点内容、保存导图等功能,通过Vue的数据双向绑定,更新思维导图的数据并重新渲染图表。 以上是用Vue 3和AntV实现思维导图的基本步骤,具体的实现方式可以根据项目需求进行调整和扩展。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值