vue3 + antv/x6 实现拖拽侧边栏节点到画布

前篇:vue3+ts使用antv/x6 + 自定义节点
前篇:vue3+antv x6自定义节点样式

1、创建侧边栏

  • 用antd的menu来做侧边栏
sql 复制代码
npm i --save ant-design-vue@4.x
js 复制代码
//入口文件main.js内
import Antd from 'ant-design-vue';
import App from './App';
import 'ant-design-vue/dist/reset.css';

const app = createApp(App);
app.use(Antd).mount('#app');
  • 侧边栏结构
json 复制代码
// index.js内,拖拽节点侧边栏
export const MENU_TREE = [
    {
        key: '1',
        label: 'type1',
        title: 'drag node 1',
    },
]
  • 画布展示
js 复制代码
//index.vue内
<template>
    <div class="box">
        <a-menu
            class="menutree"
            :items="menutree"
        />
        <div id="container"></div>
    </div>
    <TeleportContainer/>
</template> 
<script setup lang='ts'>
import {MENU_TREE} from "./index";
let menutree = MENU_TREE
</script>
<style scoped>
.menutree{
    display: flex;
    position: relative;
}
#container{
    height: 100vh;
}
.menutree{
    width: 200px;
    height: 100vh;
    position: absolute;
    left: 0;
    top: 0;
    flex-direction: column;
    z-index: 2;
  	user-select: none;/* 鼠标按下时没有复制等操作 */
}
</style>    

2、拖拽交互

  • 安装
sql 复制代码
  npm install @antv/x6-plugin-dnd --save
  • 引入并使用(index.vue)
js 复制代码
import { Dnd } from '@antv/x6-plugin-dnd'
//...
let dnd:Dnd
//开始拖拽
const startDrag = (e,nodevo)=>{
    const node = graph.createNode(formatData(nodevo))
    dnd.start(node, e)
}
//初始化画布
const graphInit = ()=>{
    //...
    dnd = new Dnd({
        target: graph,
        getDragNode: (node) => node.clone({ keepId: true }),//拖拽开始时,获取被拖拽的节点,默认克隆 dnd.start 传入的节点。
        getDropNode: (node) => {//拖拽结束时,获取放置到目标画布的节点,默认克隆被拖拽的节点。
            return graph.createNode(formatData(node.getData()))
        }
    })
}

3、侧边栏和拖拽建立联系

  • 在侧边栏menu中添加拖拽节点信息(index.js)
json 复制代码
MENU_TREE = [{
    key: '1',
    label: 'type1',
    title: 'drag node 1',
    ports:[{
        id: 'port-1',
        name: 'drag1-port1',
    }]
}]
  • fomatMenu处理menu内需要拖拽到节点信息(index.js)
js 复制代码
export function fomatMenu (menu: any, dragStart) {
    let tempmenu = menu.map(ele => {
        const nodeVO = {
            id: `node-${Math.random()}`,
            nodeName: ele.title,
            x: 0,
            y: 0,
            ports: ele.ports
        }
        return {
            key: ele.key,
            label: ele.label,
            onMousedown: (e: Event) => {
                dragStart(e, nodeVO)
            },
        }
    });
    return tempmenu
}
  • 主画布渲染menu时先处理menu信息
js 复制代码
import {MENU_TREE,fomatMenu} from "./index";
let menutree = fomatMenu(MENU_TREE,startDrag) //放在startDrag之后
  • 效果
相关推荐
程序员爱钓鱼12 小时前
Node.js 编程实战:图像与文件上传下载
前端·后端·node.js
kong790692813 小时前
环境搭建-运行前端工程(vue)
前端·前端环境
谷歌开发者13 小时前
Web 开发指向标|开发者工具 AI 辅助功能的 5 大实践应用
前端·人工智能
晚烛19 小时前
实战前瞻:构建高可靠、强协同的 Flutter + OpenHarmony 智慧教育平台
javascript·flutter·html
@AfeiyuO19 小时前
Vue3 矩形树图
vue·echarts
快乐肚皮19 小时前
一文了解XSS攻击:分类、原理与全方位防御方案
java·前端·xss
保护我方头发丶19 小时前
ESP-wifi-蓝牙
前端·javascript·数据库
想学后端的前端工程师20 小时前
【Flutter跨平台开发实战指南:从零到上线-web技术栈】
前端·flutter
老王Bingo20 小时前
Qwen Code + Chrome DevTools MCP,让爬虫、数据采集、自动化测试效率提升 100 倍
前端·爬虫·chrome devtools
董世昌4120 小时前
什么是扩展运算符?有什么使用场景?
开发语言·前端·javascript