热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【用JS自制表格软件玩数据】8.设计单元格中的右键菜单

右键菜单选项的设计效果图基本数据分析功能菜单的渲染模块右键菜单的样式最终结果当写完本系列后,我会把源代码分享出来给大家。本课程也会持续更新与矫正。欢迎留言指正


右键菜单选项的设计

  • 效果图
  • 基本数据
    • 分析
  • 功能
  • 菜单的渲染模块
  • 右键菜单的样式
  • 最终结果


当写完本系列后,我会把源代码分享出来给大家。本课程也会持续更新与矫正。欢迎留言指正!



效果图

在这里插入图片描述


基本数据

首先构建一个基本的配置数据

/**
* @property {Array} contextmenulist 右键菜单列表*/

this.contextmenulist &#61; [{"icon": "","name": "复制","event": function () { }},{"icon": "","name": "剪切","event": function () { }},{"icon": "","name": "粘贴","event": function () { }},{"icon": "","name": "清空全部格式","event": function () {var cells__inputs &#61; document.getElementsByClassName("cells__input");var length &#61; cells__inputs.length;for(var i &#61; 0;i<length;i&#43;&#43;){cells__inputs[i].setAttribute("style","");}}}
];

分析


属性说明
icon图标
name按钮的文字
event点击该按钮后会执行的代码

功能

cellcontextmenu(ev){var that &#61; this// 一个复制对象的函数function copy (array) {let newArray &#61; []for(let item of array) {newArray.push(item);}return newArray;}var target &#61; ev.target || ev.srcElement;// 将前面的菜单配置文件复制一个副本出来var contextmenulist &#61; copy(that.contextmenulist);// 这个地方是将菜单项的列表渲染出来&#xff0c;具体的代码可以看下面的代码块that.updata_contextmenulist(contextmenulist,that.right__menu_list)console.log("单元格右击",target.getAttribute("data-x"),target.getAttribute("data-y"))// 前面渲染成功后的菜单是透明不可见的&#xff0c;下面的代码要把渲染的菜单&#xff0c;显示出来var oDiv &#61; document.getElementById(that.right__menu);oDiv.style.display &#61; "block";oDiv.style.left &#61; ev.clientX&#43;"px";oDiv.style.top &#61; ev.clientY&#43;"px";that.focus["x"] &#61; target.getAttribute("data-x");that.focus["y"] &#61; target.getAttribute("data-y");console.log(that.focus);}

菜单的渲染模块

updata_contextmenulist(contextmenulist,id){ // 鼠标右键菜单刷新this.empty_id(id)var len &#61; contextmenulist.length;var Tags &#61; [];for(var i &#61; 0; i < len; i&#43;&#43; ){// right__menu__element 是菜单的样式Tags.push({"Tag" : "li", "ID" : this.creatGlobalId(), "ClassName" : "right__menu__element", "Text":contextmenulist[i]["name"],"Data" : [{ "k":"id", "v":i }],"Action":{"click":function(ev){var target &#61; ev.target || ev.srcElement;console.log("右键菜单按钮"&#43;target.getAttribute("data-id")&#43;"点击事件");contextmenulist[target.getAttribute("data-id")]["event"]();}}});}this.renderDOM(id,Tags,function(target){},function(target){});}

右键菜单的样式

.right__menu{position: absolute;background: #fff;border: 1px solid black;display: none;
}.right__menu__element{list-style-type: none;margin: 10px;text-align: left;cursor:default;
}

最终结果


这个右键菜单会跟着鼠标的位置一起展示&#xff0c;如果点击其他位置&#xff0c;它就会消失。这里面用到了事件的冒泡机制。我后面会在更深一步介绍渲染器的代码里详细介绍到。


在这里插入图片描述

在这里插入图片描述


推荐阅读
  • 本文将详细探讨Linux pinctrl子系统的各个关键数据结构,帮助读者深入了解其内部机制。通过分析这些数据结构及其相互关系,我们将进一步理解pinctrl子系统的工作原理和设计思路。 ... [详细]
  • PHP 过滤器详解
    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
  • 本文详细介绍了如何通过RPM包在Linux系统(如CentOS)上安装MySQL 5.6。涵盖了检查现有安装、下载和安装RPM包、配置MySQL以及设置远程访问和开机自启动等步骤。 ... [详细]
  • Kubernetes 持久化存储与数据卷详解
    本文深入探讨 Kubernetes 中持久化存储的使用场景、PV/PVC/StorageClass 的基本操作及其实现原理,旨在帮助读者理解如何高效管理容器化应用的数据持久化需求。 ... [详细]
  • Python处理Word文档的高效技巧
    本文详细介绍了如何使用Python处理Word文档,涵盖从基础操作到高级功能的各种技巧。我们将探讨如何生成文档、定义样式、提取表格数据以及处理超链接和图片等内容。 ... [详细]
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
  • 本文详细介绍了 RosPack 类的功能和用法,探讨了其在 ROS 系统中的重要作用。RosPack 类提供了类似于终端命令 rospack 的功能,能够方便地查询和管理 ROS 包的相关信息。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • Struts与Spring框架的集成指南
    本文详细介绍了如何将Struts和Spring两个流行的Java Web开发框架进行整合,涵盖从环境配置到代码实现的具体步骤。 ... [详细]
  • 在软件开发过程中,MD5加密是一种常见的数据保护手段。本文将详细介绍如何在C#中使用两种不同的方式来实现MD5加密:字符串加密和流加密。 ... [详细]
  • 本文详细介绍了如何规划和部署一个高可用的Etcd集群,包括主机配置、软件安装、防火墙设置及集群健康检查等内容。通过合理的硬件配置和网络规划,确保Etcd集群在生产环境中的稳定运行。 ... [详细]
  • 在Oracle数据库中,使用Dbms_Output.Put_Line进行输出调试时,若单行字符超过255个,则会遇到ORA-20000错误。本文介绍了一种有效的方法来处理这种情况,通过创建自定义包和视图,实现对长字符串的分割和正确输出。 ... [详细]
  • 使用lambda表达式排序Collections.sort(temp,(Stringa,Stringb)-{returnb.compareTo(a);});Collections ... [详细]
  • 对象自省自省在计算机编程领域里,是指在运行时判断一个对象的类型和能力。dir能够返回一个列表,列举了一个对象所拥有的属性和方法。my_list[ ... [详细]
  • 在创建新的Android项目时,您可能会遇到aapt错误,提示无法打开libstdc++.so.6共享对象文件。本文将探讨该问题的原因及解决方案。 ... [详细]
author-avatar
林原伟662532
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有