js实现仿桌面右键,出现右键菜单功能

简介: javascript有右键事件,可以利用这个事件,实现右键菜单功能。喜欢点个赞。转发备注出处。

最终样式如下:

image.png

功能需求:和电脑桌面一样,灰色的是自定义桌面区域(或全屏,或固定大小范围,本次为固定大小举例),绿色的为右键菜单,当点击右键时,需显示菜单,左键单点消失。
**
实现思路:**

0、首先禁用浏览器自带默认右键行为。
1、两个盒子,一个桌面区域div,一个右键菜单div。
2、菜单默认隐藏,在桌面div中点击右键,显示菜单。
3、拿到右键点击的left和top值,并将弹窗定位到这个位置。
4、最后检查点击位置,控制菜单显示区域,防止菜单超出桌面。

你需要知道的js方法:

1、右键事件:oncontextmenu
2、禁用浏览器默认行为 e.preventDefault()
3、获取div左上角坐标 div.offsetLeft 和 div.offsetTop
4、获取div实际宽高 div.getBoundingClientRect().width 和 div.getBoundingClientRect().height
5、Dom基本操作

开始:

现将样式写出来:

HTML代码:

<div id="box">
    <div id="menu">右键菜单</div>
</div>
CSS代码:

 <style>

    #box {
      width: 1000px;
      height: 600px;
      background: #Ccc;
      margin: 0 auto;
      margin-top: 100px
    }

    #menu {
      position: absolute;
      min-width: 100px;
      height: 200px;
      background: #9f9;
      display: none;
    }
    
  </style>

实现js逻辑:


    var box = document.getElementById('box'); // 桌面区域
    var menu = document.getElementById('menu') // 右键菜单
    let b_w = box.getBoundingClientRect().width; // 桌面区域宽度
    let b_h = box.getBoundingClientRect().height; // 桌面区域高度
    let b_cX = box.offsetLeft; // box左上角left
    let b_cY = box.offsetTop; //  box左上角top
    
    box.oncontextmenu = function (e) { // 右键事件
      menu.style.display = "block"; // 菜单显示
      menu.style.top = e.clientY + 'px' // 根据点击位置定位菜单位置top
      menu.style.left = e.clientX + 'px'  // 根据点击位置定位菜单位置left
      let m_w = menu.getBoundingClientRect().width; // 菜单宽度
      let m_h = menu.getBoundingClientRect().height; // 菜单高度

      // 控制菜单弹出区域,不能超过桌面右侧和下侧最大范围
      if (e.clientX > (b_cX + b_w - m_w)) {
        menu.style.left = (e.clientX - m_w) + 'px'  // 如果菜单超出桌面宽度,让菜单向左偏移本身宽度
      }
      if (e.clientY > (b_cY + b_h - m_h)) {
        menu.style.top = (b_cY + b_h - m_h - 5) + 'px'  //  如果菜单超出桌面高度,让菜单定位到这个位置,为了美观,菜单栏与底部桌面留有5px间距
      }
    }


    // window区域点击菜单栏均消失
    window.onclick = function (e) {
      menu.style.display = "none";
    }
    
    // 禁用window区域右键默认菜单弹窗
    window.oncontextmenu = function (e) {
      e.preventDefault();
    }

-
-
-

以上就是博主实现的右键菜单实现方式,如果有更好的方式,欢迎沟通。
wechat:villinWeChat

目录
相关文章
|
3月前
|
JavaScript 前端开发
JavaScript分页功能
JavaScript分页功能
|
20天前
|
JavaScript 容器
带方向感知功能的js图片遮罩层插件
带方向感知功能的js图片遮罩层插件
|
1天前
|
JavaScript 前端开发
【Vue.js】监听器功能(EventListener)的实际应用【合集】
而此次问题的核心就在于,Vue实例化的时机过早,在其所依赖的DOM结构尚未完整构建完成时就已启动挂载流程,从而导致无法找到对应的DOM元素,最终致使计算器功能出现异常,输出框错误地显示“{{current}}”,并且按钮的交互功能也完全丧失响应。为了让代码结构更为清晰,便于后续的维护与管理工作,我打算把HTML文件中标签内的JavaScript代码迁移到外部的JS文件里,随后在HTML文件中对其进行引用。
18 8
|
2月前
|
JavaScript 前端开发 容器
jQuery多功能滑块插件r-slider.js
r-slider.js是一款jQuery多功能滑块插件。使用该插件,可以制作出滑块、开关按钮、进度条、向导步骤等多种效果。
47 5
|
2月前
|
JavaScript
js实现简洁实用的网页计算器功能源码
这是一款使用js实现简洁实用的网页计算器功能源码。可实现比较基本的加减乘除四则运算功能,界面简洁实用,是一款比较基本的js运算功能源码。该源码可兼容目前最新的各类主流浏览器。
31 2
|
3月前
|
人工智能 JavaScript 网络安全
ToB项目身份认证AD集成(三完):利用ldap.js实现与windows AD对接实现用户搜索、认证、密码修改等功能 - 以及针对中文转义问题的补丁方法
本文详细介绍了如何使用 `ldapjs` 库在 Node.js 中实现与 Windows AD 的交互,包括用户搜索、身份验证、密码修改和重置等功能。通过创建 `LdapService` 类,提供了与 AD 服务器通信的完整解决方案,同时解决了中文字段在 LDAP 操作中被转义的问题。
|
3月前
|
JavaScript 前端开发 API
|
3月前
|
JavaScript API UED
vue.js怎么实现全屏显示功能
【10月更文挑战第7天】
69 1
|
3月前
|
资源调度 JavaScript UED
如何使用Vue.js实现单页应用的路由功能
【10月更文挑战第1天】如何使用Vue.js实现单页应用的路由功能
|
3月前
|
JavaScript 搜索推荐
JS中的模糊查询功能
JS中的模糊查询功能
51 1
下一篇
开通oss服务