Html让两个Dom进行连线 , 可以自定义连接的位置

javascript 复制代码
        function getXy(dom, pos) {
            var obj = {x : 0, y : 0};
            if(pos == 'button') {
                obj.x = dom.offsetLeft + dom.offsetWidth / 2;
                obj.y = dom.offsetTop + dom.offsetHeight;
            }else if(pos == 'left') {
                obj.x = dom.offsetLeft;
                obj.y = dom.offsetTop + dom.offsetHeight / 2;
            }else if(pos == 'right') {
                obj.x = dom.offsetLeft + dom.offsetWidth;
                obj.y = dom.offsetTop + dom.offsetHeight / 2;
            }else if(pos == 'top') {
                obj.x = dom.offsetLeft + dom.offsetWidth / 2;
                obj.y = dom.offsetTop;
            }
            return obj;
        }

        function connectEdges(id1, id2, color = 'red', width = '0.5' , pos1 = 'right', pos2 = 'left') {
            const dom1 = document.getElementById(id1);
            const dom2 = document.getElementById(id2);
            const svg = document.getElementById('svg-container');
            var objXy1 = getXy(dom1, pos1);
            var objXy2 = getXy(dom2, pos2);
            // 创建SVG线条
            const line = document.createElementNS('http://www.w3.org/2000/svg', 'line');
            line.setAttribute('x1', objXy1.x);
            line.setAttribute('y1', objXy1.y);
            line.setAttribute('x2', objXy2.x);
            line.setAttribute('y2', objXy2.y);
            line.setAttribute('stroke', color); // 线条颜色
            line.setAttribute('stroke-width', width); // 线条宽度
            // 将线条添加到SVG容器中
            svg.appendChild(line);
        }

                // 这是我自己的业务代码
                for(var i = 0 ; i  < data.length ; i++) {
                    var obj = data[i];
                    if(obj.source != obj.target){
                        if(obj.target.indexOf('配偶') != -1) {
                            connectEdges(obj.source, obj.target, 'red', 2, 'right', 'left');
                        }else{
                            connectEdges(obj.source, obj.target, 'blue', 0.5, 'button', 'top');
                        }
                    }
                }
相关推荐
仲夏那片海几秒前
spring web项目中常用的注解
java·前端·spring
一棵开花的树,枝芽无限靠近你5 分钟前
【element-tiptap】Tiptap编辑器核心概念----结构篇
前端·笔记·学习·编辑器
jlting1957 分钟前
《基于 PySpark 的电影推荐系统分析及问题解决》
大数据·javascript·spark
苦逼的猿宝7 分钟前
React中使用echarts写出3d旋转扇形图
前端·react.js·echarts
科技新知34 分钟前
科沃斯悬了
javascript
我要学编程(ಥ_ಥ)37 分钟前
速通前端篇 —— CSS
前端·css
黑色的糖果1 小时前
npm上传自己封装的插件(vue+vite)
前端·vue.js·npm·vite
guokanglun1 小时前
Cesium 相机系统
javascript
祭の1 小时前
HttpServletResponse响应对象讲解(笔记)
java·前端·笔记
祭の2 小时前
HttpServletRequest和⽤用户登录表单提交
java·服务器·前端