🎄Hi~ 大家好,我是小鑫同学,一位长期从事前端开发的编程爱好者,我将使用更为实用的案例输出更多的编程知识,同时我信奉分享是成长的唯一捷径,在这里也希望我的每一篇文章都能成为你技术落地的参考~
目录
1. 准备工作:
1. 初始化项目:
1.1 初始化环境:
使用
pnpm create vite
创建项目,选择Vue
框架及TypeScript
变体;
1.2 安装核心模块:
在完成了前面的准备工作后,需要安装非核心的插件依赖模块:
pnpm add @logicflow/core
pnpm add @logicflow/extension
2. 插件注册:
2.1 注册插件到全局:
import {
BpmnElement } from '@logicflow/extension';
LogicFlow.use(BpmnElement);
2.2 注册插件到实例:
import LogicFlow from "@logicflow/core";
import {
DndPanel, SelectionSelect } from "@logicflow/extension";
import "@logicflow/core/dist/style/index.css";
import "@logicflow/extension/lib/style/index.css";
const lf = new LogicFlow({
container: document.querySelector("#app"),
grid: true,
plugins: [DndPanel, SelectionSelect]
});
2. 配置拖拽面板 DndPanel:
拖拽面板的插件安装完成后就可以为拖拽面板添加元素了,也就是被拖拽的内容,每个元素都具备以下7
个可选选项进行控制:
名称 | 类型 | 描述 |
---|---|---|
type | string | 指定用户鼠标可以拖入的节点类型,包括自定义节点类型, 不传则不会创建节点,只会触发callback |
text | string | 创建节点的文本 |
properties | object | 创建节点的properties |
label | string | 拖拽面板节点文本描述 |
icon | string | 拖拽面试上显示的图标,可以传入图标url地址或base64编码 |
className | string | 额外传入可以拖拽项的class, 用于自定义拖拽项的样式 |
callback | fn | 用户鼠标按下拖拽项后触发的回调 |
<script setup lang="ts">
import LogicFlow from "@logicflow/core";
import {
DndPanel } from "@logicflow/extension";
import "@logicflow/core/dist/style/index.css";
import "@logicflow/extension/lib/style/index.css";
import {
onMounted, ref } from "vue";
const container = ref();
const lf = ref<LogicFlow>();
const patternItems = [
{
type: 'circle',
text: '开始',
label: '开始节点',
icon: '