# 工作流节点开发文档
> 参考示例:Markdown2HTML节点
## 节点入口文件
> composables/worklfow/node/Markdown2HtmlNode.ts
> 此文件定义了节点所需要的所有内容
- nodeType 节点类型
- getNodeList 节点清单,对应添加节点时,显示的内容
- initData 初始化数据,当前的插件节点,后端逻辑都是通过接口处理的
- 示例接口:`server/api/markdown2html.post.ts` **注意返回结果类型:NodeOutput**
- createOutputSpec 定义参数关联节点产出的路径
- 文本类型为 ['output_content', '*', 'content']
- 媒体类型为 ['output_content', '*', 'url']
- renderNode: 节点对应的前端组件`components/Markdown2Html/index.vue`
```typescript
import { NodeCategoryEnum, PluginBaseNode } from "./PluginBaseNode";
import {
Markdown2Html
} from '#components'
import { NodeTypeEnum } from "~/composables/worklfow/node/node.interface";
export default class Markdown2HtmlNode extends PluginBaseNode {
static override nodeType = NodeTypeEnum.Markdown2Html // 节点类型
static override getNodeList() {
return [
{
type: Markdown2HtmlNode.nodeType, // 节点类型
label: 'Markdown转HTML', // 标签
description: 'Markdown转HTML', // 描述
category: NodeCategoryEnum.BASE, // 分类
icon: 'material-symbols-light:markdown-paste' // 图标
}
]
}
initData() {
// 数据类型 IApiPluginNodeData
return {
method: 'POST', // 请求方法
url: 'http://localhost:3200/plugins/api/markdown2html', // 请求地址,节点的业务逻辑,需要在接口中完成
body: {
markdown: '' // 接口请求体内容,输入的markdown内容
},
headers: {
'Content-Type': 'application/json'
// 依据接口自行扩展,认证等信息
}
} // 初始化数据
}
/**
* 输入信息关联父节点产出的数据类型及数据路径
*/
override createOutputSpec(): INodeOutputSpec {
return {
type: 'text', // 文本类型
defaultPath: ['output_content', '*', 'content'] // 数据路径,文本为 ['output_content', '*', 'content'],媒体类型为 ['output_content', '*', 'url']
}
}
// 画布节点 UI
static override renderNode() {
return Markdown2Html // 节点组件
}
}
```
## 维护组件信息文件:
> manifest/Markdown2HtmlNode.ts
> 需要参照IComponentMateInfo类型约束文件进行定义
## 组件效果
1. 添加节点

2. 关联节点
