PathWise开发(1) 将增加节点的功能移动到鼠标右键 d3.js/vue.js

news2024/11/25 2:33:22

PathWise(1) 从零开始搭建知识图谱/个性化学习路径/d3.js/vue.js

2023年5月20日:将增加节点的功能移动到鼠标右键

跑起来先

思路:

  1. 将我们之前的MyTableAddNode.vue,删除其中的内容只留下下面的表单
    <template>
      <!-- <div class="container"> -->
        <!-- 添加下拉框 -->
        <form @submit.prevent="handleSubmit" class="light-grey-form">
          <!-- <div>
            <label for="neignbor">父节点</label>
            <input type="text" id="neignbor" v-model="neignbor">
          </div> -->
          <div>
            <label for="relation">关系名称</label>
            <input type="text" id="relation" v-model="relation" >
          </div>
          <div>
            <label for="name">节点名称</label>
            <input type="text" id="name" v-model="name" required>
            <button type="submit">提交</button>
          </div>
          <!-- <div>
            <label for="long-text">节点描述</label>
            <textarea id="long-text" v-model="longText"></textarea>
          </div> -->      
        </form>
      <!-- </div> -->
    
  1. 在鼠标右键的菜单MyContextMenuForSvgNode.vue中,我们导入上面的vue,并在template标签中添加
        <li class="context-menu-item" id="add-node" @click="toggleForm" :class="{ active: isFormVisible }">添加节点
    </li> 
    <div class="dropdown-wrapper">
        <MyTableAddNode_1 v-if="isFormVisible" @click.stop></MyTableAddNode_1>
    </div>
    
    其中第一个li设置点击事件,用来控制表单的显示和隐藏
          //添加节点表单内容的显示与隐藏
      toggleForm() {
       if (this.isFormVisible) {
        console.log(2)
          this.isFormVisible = false; // 如果表单已经显示,则隐藏表单
       }
      else{
        console.log(3)
        this.isFormVisible = true;
      }
       
       this.$bus.$emit('Table_add_node');
      },
    
  2. 默认让表单处于隐藏状态。
    这涉及到MyResizedSVG.vue的逻辑,鼠标右键点击之后,触发方法
          // 展示右键菜单栏
      showContextMenu($event,e) {
        $event.preventDefault();
        const contextMenu = this.$refs.contextMenu;
        
        // 获取 SVG 的位置信息
        const svg_info = this.$refs.mainsvg.getBoundingClientRect();
        
        // 获取鼠标点击位置
        const mouseX = $event.clientX - svg_info.left + 25;
        const mouseY = $event.clientY - svg_info.top + 10;
    
        // 显示上下文菜单并设置其位置
        let d3_menu_data = {'e':e, 'event':$event, 'mouseX':mouseX, 'mouseY':mouseY}
        // console.log('d3_menu_data',d3_menu_data)
        contextMenu.showContextMenu(d3_menu_data);
      },
    
    其中contextMenu就是MyContextMenuForSvgNode.vue这个文件,所以如果要将表单默认设定为关闭状态,只需将MyContextMenuForSvgNode.vue这个文件中的下属方法进行调整即可。
          // 展示菜单的接口
      showContextMenu(d3_menu_data) {
        this.isFormVisible=false
        console.log(123)
        // 获取数据
        this.d3_menu_data = d3_menu_data
        let mouseX = d3_menu_data.mouseX
        let mouseY = d3_menu_data.mouseY
        const contextMenu = this.$refs.contextMenu;
    
        // 更新预览
        this.initColor()
    
        // 显示上下文菜单并设置其位置
        contextMenu.style.left = `${mouseX}px`;
        contextMenu.style.top = `${mouseY}px`;
    
        // 显示上下文菜单
        // contextMenu.style.display = 'block';
        this.isMenuVisible = true;
      },
    

动图效果参考请添加图片描述

debug

一个小问题时,提交完成之后,应该将菜单栏的显示给关掉。这个组件之间的接口我们发现之前已经写好了。

        // 关闭菜单
        this.$bus.$emit('context_hide-context-menu')

在MyTableAddNode_1中handleSubmit的最后进行调用即可。重新执行,一切正常。请添加图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/548995.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Linux Network】高级IO

目录 前言 五种IO模型 阻塞IO 非阻塞IO 信号驱动IO IO多路转接 异步IO 小结 同步通信 vs 异步通信 阻塞 vs 非阻塞 其他高级IO 非阻塞IO fcntl函数 代码测试 高级IO&#x1f337; 前言 IO&#xff1a;所谓的I便是 input&#xff0c;所谓的O便是 output&#xff0c;简单点来说&a…

VC++6.0掌握哈希表的基本操作和掌握几种内部排序的方法

问题描述 针对某个集体中人名设计一个哈希表&#xff0c;使得平均查找长度不超过R&#xff0c;并完成相应的建表和查表程序。 1.2基本要求 假设人名为中国人姓名的汉语拼音形式。待填入哈希表的人名共有30个&#xff0c;取平均查找长度的上限为2。哈希函数用除留余数法构造&…

【掌控安全】sql注入全集

掌控安全 &#x1f525;系列专栏&#xff1a;掌控安全 &#x1f389;欢迎关注&#x1f50e;点赞&#x1f44d;收藏⭐️留言&#x1f4dd; &#x1f4c6;首发时间&#xff1a;&#x1f334;2023年5月20日&#x1f334; &#x1f36d;作者水平很有限&#xff0c;如果发现错误&…

Linux---文件操作命令(touch、cat、more)

1. touch命令 可以通过touch命令创建文件 语法&#xff1a;touch [选项] Linux路径 touch命令&#xff0c;参数必填&#xff0c;表示要创建的文件路径&#xff0c;相对、绝对、特殊路径符均可以使用。 touch 命令不光可以用来创建文件&#xff08;当指定操作文件不存在时&a…

【Redis】聊一下缓存雪崩、击穿、穿透、预热

缓存的引入带来了数据读取性能的提升&#xff0c;但是因此也引入新的问题&#xff0c;一个是数据双写一致性&#xff0c;另一个就是雪崩、击穿、穿透&#xff0c;那么如何解决这些问题&#xff0c;我们来说下对应的问题和解决方案 雪崩 缓存雪崩&#xff1a;同一时间内大量请…

pg事务:事务相关元组结构

事务相关的元组结构 元组结构中包含很多pg的mvcc所必要的信息&#xff0c;下面的内容将梳理xmin,xmax,t_ctid,cmin,cmax,combo cid,tuple id的含义和关系 物理结构 HeapTupleHeaderData相当于tuple的header&#xff0c;其结构在src/include/access/htup_details.h中定义 typ…

【BIO、NIO、AIO、Netty】

什么是IO Java中I/O是以流为基础进行数据的输入输出的&#xff0c;所有数据被串行化(所谓串行化就是数据要按顺序进行输入输出)写入输出流。简单来说就是java通过io流方式和外部设备进行交互。在Java类库中&#xff0c;IO部分的内容是很庞大的&#xff0c;因为它涉及的领域很广…

win--C盘程序员常见应用内存空间处理

写在前面&#xff1a; 本篇用于记录我对于C盘各个应用内存处理的总结&#xff0c; 文章目录 前置知识vscode的.vscode文件迁移可以移动 软件推荐wsl和docker存储管理修改安装目录压缩磁盘 pip缓存清理JetBrains系列 前置知识 在win中有着这样一个命令mklink&#xff0c;可以…

Java飞行记录器

目录 JFR和JMC启动飞行记录用JFR对比不同GC器运行结果记录结果GC配置GC Summary垃圾收集 JFR和JMC JFR全称为Java Flight Recorder&#xff0c;即Java飞行记录器 JMC全称为JDK Mission Control&#xff0c;即JDK任务控制 先贴一段官网的简介&#xff1a; Java Flight Recorder…

基于鸿蒙系统的智能衣柜管理系统设计与实现_kaic

摘 要 随着城市的扩大与科学技术的发展&#xff0c;人们逐渐开始关注衣柜功能的改进&#xff0c;存储效果的优化和智能使用的升级。个性化、功能化、智能化的衣柜将出现在人们的家庭生活中&#xff0c;并且起到重要作用。 为了满足当前人们对智能衣柜的需求&#xff0c;本设计…

面试真的被问麻了......

前几天组了一个软件测试面试的群&#xff0c;没想到效果直接拉满&#xff0c;看来大家对面试这块的需求还是挺迫切的。昨天我就看到群友们发的一些面经&#xff0c;感觉非常有参考价值&#xff0c;于是我就问他还有没有。 结果他给我整理了一份非常硬核的面筋&#xff0c;打开…

Java -并发(多线程)-Interview面试题收集

1、多线程并发 1&#xff09;多线程中 synchronized 锁升级的原理是什么&#xff1f; synchronized 锁升级原理&#xff1a;在锁对象的对象头里面有一个 threadid 字段&#xff0c;在第一次访问的时候 threadid 为空&#xff0c;jvm 让其持有偏向锁&#xff0c;并将 threadid…

Mabatis Plus 之ID生成策略控制(Auto、Input、assign_id、assign_uuid)

文章目录 知识点1&#xff1a;TableId1 环境构建2 代码演示AUTO策略步骤1:设置生成策略为AUTO步骤2:删除测试数据并修改自增值步骤3:运行新增方法 INPUT策略步骤1:设置生成策略为INPUT步骤2:添加数据手动设置ID步骤3:运行新增方法 ASSIGN_ID策略步骤1:设置生成策略为ASSIGN_ID步…

HTTPS的工作流程

hi,大家好,好久不见,今天为大家带来HTTPS协议的工作流程 认识HTTPS 加密是什么 HTTPS的工作流程 1.认识HTTPS HTTPS也是应用层协议,让我们再来回忆一下TCP/IP五层协议模型 HTTPS 也是一个应用层协议. 是在 HTTP 协议的基础上引入了一个加密层. HTTP协议在传输的时候是以…

2023河海大学838计算机学硕考研高分经验分享

大家好&#xff0c;我是陪你考研每一天的大巴学长。 大巴学长为大家邀请到了2023年838计算机学硕初试第二名的高分学长&#xff0c;为大家分享一下他的考研经验&#xff0c;经验里详细介绍了各科的复习方法&#xff0c;很有参考意义。 希望对大家有所借鉴和帮助&#xff0c;在…

C++13-STL模板-01向量(vector)

C13-STL模板 在线练习&#xff1a; http://noi.openjudge.cn/ https://www.luogu.com.cn/ 大纲要求 【 3 】算法模板库中的函数&#xff1a;min、max、swap、sort 【 4 】栈 (stack)、队列 (queue)、链表 (list)、 向量&#xff08;vector&#xff09;等容器 1.函数模板 泛…

HNU数据结构与算法分析-作业1-算法分析

1. (简答题) 1.&#xff08;教材3.4&#xff09;&#xff08;a&#xff09;假设某一个算法的时间代价为 &#xff0c;对于输入规模n&#xff0c;在某台计算机上实现并完成该算法的时间为t秒。现在另有一台计算机&#xff0c;运行速度为第一台的64倍&#xff0c;那么t秒内新机器…

FreeRTOS(5)----互斥量

一&#xff0c;互斥信号量 互斥信号量是一个具有优先级继承的二值信号量&#xff0c;在同步的应用中二值信号量最合适。互斥信号量适合互斥访问的那些应用。在互斥访问中互斥信号量相当于一个钥匙&#xff0c;当一个任务使用这个资源&#xff0c;资源就会被上锁&#xff0c;防…

[CTF/网络安全] 攻防世界 robots 解题详析

[CTF/网络安全] 攻防世界 robots 解题详析 robots.txt姿势总结 题目描述&#xff1a;X老师上课讲了Robots协议&#xff0c;小宁同学却上课打了瞌睡&#xff0c;赶紧来教教小宁Robots协议是什么吧。 进入靶机&#xff0c;页面空白。 查看页面源代码&#xff1a; 再次结合题目Rob…

Java常用工具之StringUtils类

目录 一、字符串判空二、分隔字符串三、判断是否为纯数字四、将集合拼接成字符串五、其他方法 字符串&#xff08;String&#xff09;在我们的日常工作中&#xff0c;用得非常非常非常多。 在我们的代码中经常需要对字符串判空&#xff0c;截取字符串、转换大小写、分隔字符串、…