HTML中自定义鼠标右键菜单

news2025/1/11 21:42:44

今天突然有人跟我提到了HTML中如何自定义鼠标右键菜单,这里大概记录一下吧,方便下次直接复制。免得还去看API文档。

文章目录

  • HTML中自定义鼠标右键菜单
    • 结果如下所示
    • 可以稍微改一下鼠标悬浮到右键菜单时的样式
    • 结果如下所示
  • 只在某个特定的div才可以显示右键菜单
    • 结果如下所示
  • 在多个特定的div中都可以显示右键菜单
    • 结果如下所示

HTML中自定义鼠标右键菜单

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>鼠标右键菜单示例</title>
    <style>
        .context-menu {
            display: none;
            position: absolute;
            background-color: #fff;
            border: 1px solid #ccc;
            min-width: 100px;
            box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.3);
            z-index: 999;
        }
        .context-menu-item {
            padding: 5px 10px;
            cursor: pointer;
        }
    </style>
</head>
<body>

<div id="contextMenu" class="context-menu">
    <div class="context-menu-item" onclick="handleItemClick('复制')">复制</div>
    <div class="context-menu-item" onclick="handleItemClick('粘贴')">粘贴</div>
    <div class="context-menu-item" onclick="handleItemClick('剪切')">剪切</div>
</div>

<script>
    document.addEventListener('contextmenu', function (e) {
        e.preventDefault(); // 阻止默认右键菜单

        var menu = document.getElementById('contextMenu');
        menu.style.display = 'block';
        menu.style.left = `${e.pageX}px`;
        menu.style.top = `${e.pageY}px`;
    });

    document.addEventListener('click', function () {
        document.getElementById('contextMenu').style.display = 'none'; // 点击页面其他地方隐藏菜单
    });

    function handleItemClick(itemName) {
        console.log(`用户点击了菜单项:${itemName}`);
        // 在此处添加实际的业务逻辑,如执行复制、粘贴或剪切操作
        switch (itemName) {
            case '复制':
                // 执行复制操作...
                break;
            case '粘贴':
                // 执行粘贴操作...
                break;
            case '剪切':
                // 执行剪切操作...
                break;
        }
        document.getElementById('contextMenu').style.display = 'none'; // 点击菜单项后隐藏菜单
    }
</script>

</body>
</html>

结果如下所示

在这里插入图片描述
在这个例子中,当用户在网页上右键点击时,会显示一个自定义菜单。并在点击菜单项时执行相应的函数。这个就要根据自己具体的实际场景中实现了。

可以稍微改一下鼠标悬浮到右键菜单时的样式

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>鼠标右键菜单示例</title>
    <style>
        .context-menu {
            display: none;
            position: absolute;
            background-color: #fff;
            border: 1px solid #ccc;
            min-width: 100px;
            box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.3);
            z-index: 999;
        }
        .context-menu-item {
            padding: 5px 10px;
            cursor: pointer;
        }
        .context-menu-item:hover {
            background-color: #e6f7ff;
        }
    </style>
</head>
<body>

<div id="contextMenu" class="context-menu">
    <div class="context-menu-item" onclick="handleItemClick('复制')">复制</div>
    <div class="context-menu-item" onclick="handleItemClick('粘贴')">粘贴</div>
    <div class="context-menu-item" onclick="handleItemClick('剪切')">剪切</div>
</div>

<script>
    document.addEventListener('contextmenu', function (e) {
        e.preventDefault(); // 阻止默认右键菜单

        var menu = document.getElementById('contextMenu');
        menu.style.display = 'block';
        menu.style.left = `${e.pageX}px`;
        menu.style.top = `${e.pageY}px`;
    });

    document.addEventListener('click', function () {
        document.getElementById('contextMenu').style.display = 'none'; // 点击页面其他地方隐藏菜单
    });

    function handleItemClick(itemName) {
        console.log(`用户点击了菜单项:${itemName}`);
        // 在此处添加实际的业务逻辑,如执行复制、粘贴或剪切操作
        switch (itemName) {
            case '复制':
                // 执行复制操作...
                break;
            case '粘贴':
                // 执行粘贴操作...
                break;
            case '剪切':
                // 执行剪切操作...
                break;
        }
        document.getElementById('contextMenu').style.display = 'none'; // 点击菜单项后隐藏菜单
    }
</script>

</body>
</html>

结果如下所示

在这里插入图片描述

只在某个特定的div才可以显示右键菜单

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>鼠标右键菜单示例</title>
    <style>
        .context-menu {
            display: none;
            position: absolute;
            background-color: #fff;
            border: 1px solid #ccc;
            min-width: 100px;
            box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.3);
            z-index: 999;
        }
        .context-menu-item {
            padding: 5px 10px;
            cursor: pointer;
        }
        .context-menu-item:hover {
            background-color: #f5f5f5;
        }
    </style>
</head>
<body>

<div id="targetDiv" style="width: 300px; height: 300px; background-color: #eee;">
    右键点击我显示自定义菜单
</div>

<div id="contextMenu" class="context-menu">
    <div class="context-menu-item" onclick="handleItemClick('复制')">复制</div>
    <div class="context-menu-item" onclick="handleItemClick('粘贴')">粘贴</div>
    <div class="context-menu-item" onclick="handleItemClick('剪切')">剪切</div>
</div>

<script>
    const targetDiv = document.getElementById('targetDiv');

    targetDiv.addEventListener('contextmenu', function (e) {
        e.preventDefault(); // 阻止默认右键菜单

        if (e.target === targetDiv) { // 只有当点击的目标是目标div时才显示菜单
            var menu = document.getElementById('contextMenu');
            menu.style.display = 'block';
            menu.style.left = `${e.pageX}px`;
            menu.style.top = `${e.pageY}px`;
        }
    });

    document.addEventListener('click', function () {
        document.getElementById('contextMenu').style.display = 'none'; // 点击页面其他地方隐藏菜单
    });

    function handleItemClick(itemName) {
        console.log(`用户点击了菜单项:${itemName}`);
        // 在此处添加实际的业务逻辑,如执行复制、粘贴或剪切操作
        switch (itemName) {
            case '复制':
                // 执行复制操作...
                break;
            case '粘贴':
                // 执行粘贴操作...
                break;
            case '剪切':
                // 执行剪切操作...
                break;
        }
        document.getElementById('contextMenu').style.display = 'none'; // 点击菜单项后隐藏菜单
    }
</script>

</body>
</html>

结果如下所示

在这里插入图片描述
在这个例子中,右键菜单只会出现在具有ID为targetDiv的div元素上。当用户在其他位置右键点击时,不会显示自定义菜单。

在多个特定的div中都可以显示右键菜单

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>鼠标右键菜单示例</title>
    <style>
        .context-menu {
            display: none;
            position: absolute;
            background-color: #fff;
            border: 1px solid #ccc;
            min-width: 100px;
            box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.3);
            z-index: 999;
        }
        .context-menu-item {
            padding: 5px 10px;
            cursor: pointer;
        }
        .context-menu-item:hover {
            background-color: #24d0d6;
        }
    </style>
</head>
<body>

<div id="targetDiv1" class="target-divs" style="width: 300px; height: 300px; background-color: #eee;">
    右键点击我显示自定义菜单
</div>

<div id="targetDiv2" class="target-divs" style="width: 300px; height: 300px; background-color: #ddd;">
    右键点击我显示自定义菜单
</div>

<div id="contextMenu" class="context-menu">
    <div class="context-menu-item" onclick="handleItemClick('复制')">复制</div>
    <div class="context-menu-item" onclick="handleItemClick('粘贴')">粘贴</div>
    <div class="context-menu-item" onclick="handleItemClick('剪切')">剪切</div>
</div>

<script>
    const targetDivs = document.getElementsByClassName('target-divs');

    for (const div of targetDivs) {
        div.addEventListener('contextmenu', function (e) {
            e.preventDefault(); // 阻止默认右键菜单

            var menu = document.getElementById('contextMenu');
            menu.style.display = 'block';
            menu.style.left = `${e.pageX}px`;
            menu.style.top = `${e.pageY}px`;
        });
    }

    document.addEventListener('click', function () {
        document.getElementById('contextMenu').style.display = 'none'; // 点击页面其他地方隐藏菜单
    });

    function handleItemClick(itemName) {
        console.log(`用户点击了菜单项:${itemName}`);
        // 在此处添加实际的业务逻辑,如执行复制、粘贴或剪切操作
        switch (itemName) {
            case '复制':
                // 执行复制操作...
                break;
            case '粘贴':
                // 执行粘贴操作...
                break;
            case '剪切':
                // 执行剪切操作...
                break;
        }
        document.getElementById('contextMenu').style.display = 'none'; // 点击菜单项后隐藏菜单
    }
</script>

</body>
</html>

结果如下所示

在这里插入图片描述
在这个例子中,我们首先通过类名target-divs获取所有需要添加右键菜单功能的div元素,然后遍历这个集合,为每个元素添加右键菜单事件监听器。这样,在任何具有target-divs类名的div上右键点击时都会显示自定义菜单。

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

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

相关文章

来不及了!大学必须完成的四件事!

老师们常说&#xff0c;上大学就轻松了 其实不然 大学不是人生的终点&#xff0c;而是新的起跑线 不是休息站&#xff0c;而是进入社会的最后冲刺跑道 大学生活苦乐参半&#xff0c;成人世界即将来临 出了校门&#xff0c;你会发现社会复杂多变&#xff0c;需要不断学习 稍…

C++之结构体以及通讯录管理系统

1&#xff0c;结构体基本概念 结构体属于自定义的数据概念&#xff0c;允许用户存储不同的数据类型 2&#xff0c;结构体的定义和使用 语法&#xff1a;struct 结构体名{ 结构体成员列表}&#xff1b; 通过结构体创建变量的方式有三种&#xff1a; 1&#xff0c;struct …

在Jupyter-lab中使用RDKit画分子2D图

在Jupyter-lab中使用RDKit画分子2D图 在做完分子对接后&#xff0c;想看看筛选后的分子的结构。因此想利用Jupyter-lab来画分子的2D图。 1. 安装Jupyter-lab与RDKit 系统&#xff1a;Win11已安装conda RDKit 是一个功能强大、灵活易用的化学信息学工具包&#xff0c;广泛应…

前端CSS常考问题总结

目录 CSS盒模型 CSS选择器的优先级 隐藏元素的方法 px和rem的区别是什么? 重绘重排有什么区别? 重排&#xff08;回流&#xff09;&#xff1a; 重绘&#xff1a; 浏览器的渲染机制: 浏览器如何解析CSS&#xff1f; 元素水平垂直居中的方式 CSS的哪些属性哪些可以…

队列循环——C++引用详解【入队元素不引用 出队元素引用】(C语言版)

出队元素引用 入队元素不引用解释&#xff1a; 在给定的代码中&#xff0c;对于 DeQueue 函数的参数使用引用 (&)&#xff0c;而对于 EnQueue 函数的参数没有使用引用&#xff0c;是基于函数内部对这些参数值的修改方式来确定的。 让我们分析一下每个函数&#xff1a; En…

SQL-Labs靶场“29-31”关通关教程

君衍. 一、二十九关 基于错误的WAF单引号注入1、源码分析2、HTTP参数污染3、联合查询注入4、updatexml报错注入 二、三十关 基于错误的WAF双引号注入1、源码分析2、联合查询注入3、updatexml报错注入 三、三十一关 基于错误的WAF双引号括号注入1、源码分析2、联合查询注入3、up…

windows10下如何通过命令行方式新增一个外部WLAN的Wifi热点并连接

☞ ░ 前往老猿Python博客 ░ https://blog.csdn.net/LaoYuanPython 一、背景 最近碰到2个家人windows下连接电脑热点的问题&#xff0c;一个是在某个培训场所显示的热点名称不是公布的热点名称&#xff0c;而是一个乱码&#xff0c;在家里和工作单位热点则显示正常&#xff…

【二叉搜索树】【前后指针】Leetcode 501. 二叉搜索树中的众数

【二叉搜索树】【前后指针】Leetcode 501. 二叉搜索树中的众数 解法1 中序遍历双指针解法2 我的复杂方法 先中序遍历到数组&#xff0c;之后hashmap遍历判断众数 之后转化为数组输出 ---------------&#x1f388;&#x1f388;题目链接&#x1f388;&#x1f388;-----------…

(已解决)emoji及其特殊符号在vue中的使用

问题叙述 使用问题&#xff1a;在表情库中点击后无法展示对应的emoji表情&#xff0c;仅仅显示Unicode代码编号&#xff0c;按照vue eslint规则更改添加分号后&#xff0c;没有报错但是依旧无法正确渲染。 问题源码&#xff1a; <template><div><!-- 被点击的…

KubeSphere简介,功能介绍,优势,架构说明及应用场景

KubeSphere 是在目前主流容器调度平台 Kubernetes 之上构建的企业级分布式多租户容器平台&#xff0c;提供简单易用的操作界面以及向导式操作方式&#xff0c;在降低用户使用容器调度平台学习成本的同时&#xff0c;极大减轻开发、测试、运维的日常工作的复杂度&#xff0c;旨…

【问题解决】| 关于torch无法使用GPU的一些实验探索,思考

文章目录 1 研究背景2 问题解决2.1 问题一&#xff0c;这两个版本分别是怎么得到的&#xff1f;2.2 问题二&#xff0c;Windows下安装CUDA Tookit 是必须的吗&#xff1f;2.3 问题三&#xff0c;驱动版本必须大于等于运行时版本吗&#xff1f;2.4 问题四&#xff0c;只运行pip …

力扣110 平衡二叉树 Java版本

文章目录 题目描述代码 题目描述 给定一个二叉树&#xff0c;判断它是否是高度平衡的二叉树。 本题中&#xff0c;一棵高度平衡二叉树定义为&#xff1a; 一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1 。 示例 1&#xff1a; 输入&#xff1a;root [3,9,…

python笔记_程序流程控制

A&#xff0c;顺序控制 程序从上到下逐行执行 python定义变量时&#xff0c;会合法地向前引用 age 1 age2 age 1 age2 age 1 age 1 ——>错误&#xff0c;age应在age2之前 B&#xff0c;分支控制 1&#xff0c;单分支if 语法 if 条件表达式 &#xff1a; 代码块 说明…

代码随想录day10(2)字符串:反转字符串Ⅱ (leetcode541)

题目要求&#xff1a;给定一个字符串 s 和一个整数 k&#xff0c;从字符串开头算起, 每计数至 2k 个字符&#xff0c;就反转这 2k 个字符中的前 k 个字符。如果剩余字符少于 k 个&#xff0c;则将剩余字符全部反转。如果剩余字符小于 2k 但大于或等于 k 个&#xff0c;则反转前…

两天学会微服务网关Gateway-Gateway简介

锋哥原创的微服务网关Gateway视频教程&#xff1a; Gateway微服务网关视频教程&#xff08;无废话版&#xff09;_哔哩哔哩_bilibiliGateway微服务网关视频教程&#xff08;无废话版&#xff09;共计17条视频&#xff0c;包括&#xff1a;1_Gateway简介、2_Gateway工作原理、3…

Git 基于ED25519、RSA算法生成 SSH 密钥

Git 基于ED25519、RSA算法生成 SSH 密钥 基于ED25519算法&#xff0c;生成密钥对命令如下&#xff1a; ssh-keygen -t ed25519 -C "邮箱地址"基于RSA算法&#xff0c;生成密钥对命令如下&#xff1a; ssh-keygen -t rsa -C "<注释内容>"基于ED255…

中国各省绿色金融试点DID数据集(2010-2023)

一、数据简介 最新的2010-2023年中国31省绿色金融试点DID数据&#xff0c;供大家研究使用。 数据说明&#xff1a;内含绿色金融改革创新试验区名单&#xff0c;将试验区获批当年及以后的政策虚拟变量项是否试点赋值为1&#xff0c;获批之前赋值为0。其中赣江新区、贵安新区为国…

MySQL基础-----SQL语句之DDL语句

目录 前言 开启登录数据库 一、数据库操作 1.查询所有数据库 2.切换使用数据库 3.查询当前使用的数据库 4.创建数据库 创建一个hello数据库, 使用数据库默认的字符集。 创建一个itheima数据库&#xff0c;并且指定字符集 5.删除数据库 二、表操作 1.查询当前数据库所有…

递归与递推(蓝桥杯 c++)

目录 题目一&#xff1a; 代码&#xff1a; 题目二: 代码&#xff1a; 题目三&#xff1a; 代码&#xff1a; 题目四&#xff1a; 代码&#xff1a; 题目一&#xff1a; 代码&#xff1a; #include<iostream> #include<cstring> using namespace std; int …

deep learning with pytorch(一)

1.create a basic nerual network model with pytorch 数据集 Iris UCI Machine Learning Repository fully connected 目标:创建从输入层的代码开始&#xff0c;向前移动到隐藏层&#xff0c;最后到输出层 # %% import torch import torch.nn as nn import torch.nn.funct…