VueFlow学习随笔
大约 3 分钟
VueFlow学习随笔
VueFlow学习笔记 (开发者的学习杂记)
Main
- 大部分看官网文档就行了
- 然后一部分可能在代码注释里
- 剩余的笔记,才会做在这里
原理
- 拖拽相关: D3.js
- 自定义节点: 见NodeFlow.vue,运用的自定义插槽。VueFlow标签先通过传入的数据构造有自定义标签的插槽位置,然后再用具名插槽v-slot(简写#)把插槽内容进行插入/替换。 我自定义也仿照这个设计做了 "自定义 节点项"
- 其他: VueUse
组合式函数部分
参考:https://vueflow.dev/typedocs/
注意:以下说的 “原信息” 指传入节点/socket/edge组件时的props信息,而非对象信息。 对象信息通常要根据 “原信息” 提供的id,再使用如 getConnectedEdges(id)
的API获取
- useConnection | 可组合用于访问当前正在进行的连接,返回:当前连接:startHandle、endHandle、status、position
- useEdge | (核心) 可组合访问边缘对象及其 dom 元素
- useEdgesData | (核心)
- useGetPointerPosition
- useHandle | (核心)
useHandleConnections| (核心) (弃用,useNodeConnections
代替) 与所选handle连接的线的原信息- useKeyPress
- useNode | (核心)
- useNodeConnections | (核心) (1.42.0 最近新增的) 检索连接到一个节点的所有边。可以通过句柄类型和id进行过滤
- useNodeId | (核心)
- useNodesData | (核心) 节点的原信息
- useNodesInitialized
- useVueFlow
- useZoomPanHelper
// 除文档,可以参考 node_modules/@vue-flow/core/dist/composables/,这下面都是组合式函数
// 学习要点:
// 需要区分 useXXX、useXXXId、useXXXsData 三者
// 需要区分 edge、connect
// ----------------------- Node -----------------------------
/**
* 可组合,提供对节点对象、父节点对象、连接边及其 dom 元素的访问
* 如果没有提供节点 ID,则从上下文中注入节点 ID
* 如果你不提供 ID,则必须在自定义节点组件的子级中调用此可组合项,否则将抛出
*
* @return (object{
* connectedEdges
* id: string
* node
* nodeEl
* parentNode
* })
*/
useNode
/**
* 此可组合项从 ctx 返回当前节点 id。
* 它应该在(自定义)节点组件 ctx 内部使用,因为 id 由内部NodeWrapper组件提供。
*
* @return (id: string)
*/
useNodeId
/**
* 可组合用于接收一个或多个节点的数据
*
* @return ComputedRef< NodeData< NodeType>[]>
* NodeData: { id, type, data }
*/
useNodesData
// ----------------------- Edge -----------------------------
/**
* 可组合访问边缘对象及其 dom 元素
* 如果没有提供边缘 ID,则从上下文中注入边缘 ID
* 如果你不提供 ID,则必须在自定义边缘组件的子级中调用此可组合项,否则将抛出
*
* @return (object {
* id: string,
* edge,
* edgeEl,
* })
*/
useEdge
/**
* 可组合用于接收一个或多个节点的数据
* @return (ComputedRef<EdgeData<EdgeType> | null>) 数据对象数组
* EdgeData: { id, type, data }
*/
useEdgesData
/**
* 可组合用于访问当前正在进行的连接
*
* @return (object {
* startHandle,
* endHandle,
* status,
* position,
* })
*/
useConnection
/**
* 返回的现有连接的可组合项<Handle />
*
* @return (ComputedRef< HandleConnection[]>)
* HandleConnection: {
* edgeId: string,
* source: string,
* sourceHandle: string,
* target: string,
* targetHandle: string,
* }
*/
useHandleConnections
// ----------------------- Handle ---------------------------
/**
* 此可组合项提供处理事件的监听器
* 通常建议使用 `<Handle />` 组件来代替此可组合项
* @return (object {
* handleClick(),
* handlePointerDown(),
* })
*/
useHandle
// ----------------------- Other ----------------------------
/**
* 返回用于获取指针位置的函数的可组合项
* @return (Function)
*/
useGetPointerPosition
/**
* 如果按下某个键,则返回布尔值的可组合项
* @return (Ref< boolean>)
*/
useKeyPress
/**
* 可组合用于获取所有节点的初始化状态。
*
* 当新节点添加到图中时,它不会立即初始化。这是因为节点的边界尚不清楚。当所有节点都初始化后,即当它们的边界已知时,此可组合项将返回 false,然后返回 true。
*
* @return (ComputedRef< boolean>)
*/
useNodesInitialized
/**
* 提供对存储实例的访问的可组合项
*
* 如果没有提供 id,则从上下文中注入 store 实例
*
* 如果在上下文中没有找到存储实例,则创建一个新的存储实例并在存储中注册
*
* @return (VueFlowStore)
*/
useVueFlow
/**
* 使用缩放平移助手
*
* @deprecated 改用useVueFlow
*/
useZoomPanHelper
链接到当前文件 0
没有文件链接到当前文件