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');
                        }
                    }
                }
相关推荐
lightgis13 小时前
16openlayers加载COG(云优化Geotiff)
前端·javascript·html·html5
小飞大王66613 小时前
TypeScript核心类型系统完全指南
前端·javascript·typescript
你的人类朋友15 小时前
✍️记录自己的git分支管理实践
前端·git·后端
合作小小程序员小小店16 小时前
web网页开发,在线考勤管理系统,基于Idea,html,css,vue,java,springboot,mysql
java·前端·vue.js·后端·intellij-idea·springboot
防火墙在线16 小时前
前后端通信加解密(Web Crypto API )
前端·vue.js·网络协议·node.js·express
Jacky-00816 小时前
Node + vite + React 创建项目
前端·react.js·前端框架
CoderYanger17 小时前
前端基础——CSS练习项目:百度热榜实现
开发语言·前端·css·百度·html·1024程序员节
i_am_a_div_日积月累_17 小时前
10个css更新
前端·css
她是太阳,好耀眼i17 小时前
Nvm 实现vue版本切换
javascript·vue.js·ecmascript
蒲公英100117 小时前
在wps软件的word中使用js宏命令设置表格背景色
javascript·word·wps