你还在为画各种流程图头疼吗?

1.官方文档

vueflow.dev/

Vue Flow 简介

Vue Flow 是一个专为 Vue 3 设计的可视化流程编辑库,灵感来自 React Flow。它提供了拖拽、缩放、连接、高亮等一系列交互能力,适合用于流程图、业务流程编排、数据流、低代码画布等场景。核心特点:

  1. 组件化节点:节点、边都可用 Vue 组件自定义,易于扩展。
  2. 强交互性:内置拖拽、选择框、多选、键盘快捷键等交互。
  3. 可视化状态管理 :通过 useVueFlow 暴露节点/边/视图状态与增删改查 API。
  4. 插件生态:MiniMap、Background、Controls 等增强组件可直接引入。
  5. 性能优化:虚拟化渲染、事件去抖等,适合中大型画布。

文档入口:vueflow.dev/guide/intro... | Vue Flow")


最小示例 Demo

以下示例展示两节点一条边的基本用法,可直接放在 Vue SFC 中运行(例如 Vue Flow Playground 或 Vite 项目)。

php 复制代码
<template>
  <div style="width: 100%; height: 500px">
    <VueFlow
      v-model:nodes="nodes"
      v-model:edges="edges"
      fit-view
    >
      <Background />
      <Controls />
    </VueFlow>
  </div>
</template>
<script setup lang="ts">
import { ref } from 'vue'
import { VueFlow, Background, Controls } from '@vue-flow/core'
import '@vue-flow/core/dist/style.css'
import '@vue-flow/core/dist/theme-default.css'

const nodes = ref([
  {
    id: '1',
    position: { x: 0, y: 50 },
    data: { label: '开始' },
  },
  {
    id: '2',
    position: { x: 200, y: 150 },
    data: { label: '结束' },
  },
])

const edges = ref([
  { id: 'e1-2', source: '1', target: '2', animated: true },
])
</script>

关键点说明:

  1. VueFlow 组件接收 nodesedges 数组,可通过 v-model 实时同步状态。
  2. 节点 data.label 默认会在内置 Node 中渲染;也可通过 vueFlow.registerNode 或插槽自定义。
  3. fit-view 自动将视图缩放居中到所有节点。
  4. BackgroundControls 是官方提供的 UI 插件,分别渲染网格背景和缩放/定位控件。
  5. 若需要事件处理(如拖拽回调、连线校验),可通过 useVueFlow() 获取 onEdgeUpdate, addEdges 等 API。

需要更复杂的例子(自定义节点、交互、动态加载等),可以在文档中的 "Examples" 或 "Cookbook" 章节查阅。

相关推荐
Zoey的笔记本19 小时前
敏捷与稳定并行:Scrum看板+BPM工具选型指南
大数据·前端·数据库·python·低代码
文心快码BaiduComate19 小时前
0代码手写!体验百度Comate的“魔法”:我造了个会理解情绪的中介层
前端·程序员·前端框架
38242782719 小时前
表单提交验证:onsubmit与return详解
前端·javascript·html
前端小蜗19 小时前
普通前端程序员的 2025:没什么大胜利,但也没被生活击倒
前端
bug总结19 小时前
身份证号脱敏的正确实现
前端·javascript·vue.js
林太白20 小时前
Vite8 Beta来了,Rolldown携手Oxc
前端·javascript·后端
xkxnq20 小时前
第二阶段:Vue 组件化开发(第 19天)
前端·javascript·vue.js
技术净胜21 小时前
Python 操作 Cookie 完全指南,爬虫与 Web 开发实战
前端·爬虫·python
神奇的程序员21 小时前
Nginx日志分析工具-NginxPulse开源了
前端
我是小疯子6621 小时前
前端开发入门:HTML、CSS与JS学习指南
前端