js实现右键弹出自定义菜单


Posted in Javascript onSeptember 08, 2020

近期在项目中有一个右键菜单的需求,发现很多实现都比较复杂,于是自己花了一点时间稍微研究了一下,下面提供一个简洁的实现方法。

js声明部分:

//创建右键菜单
var epMenu={
  create:function(point,option){
    var menuNode=document.getElementById('epMenu');
    if(!menuNode){
      //没有菜单节点的时候创建一个
      menuNode=document.createElement("div");
      menuNode.setAttribute('class','epMenu');
      menuNode.setAttribute('id','epMenu');
    }else $(menuNode).html('');//清空里面的内容

    $(menuNode).css({left:point.left+'px',top:point.top+'px'});
    for(var x in option){
      var tempNode=document.createElement("a");
      $(tempNode).text(option[x]['name']).on('click',option[x].action);
      menuNode.appendChild(tempNode);
    }

    $("body").append(menuNode);
  },
  destory:function(){
    $(".epMenu").remove();
  }  
};

function sayhello(){
  alert("hellokity");
  epMenu.destory();
}

function hideSysMenu() {
  return false;
}

css样式定义部分:

.epMenu{ width:120px; background:#f0f0f0; position:fixed; left:0; top:0; box-shadow:2px 2px 2px 2px #807878;}
.epMenu a{ display:block; height:25px; line-height:25px; padding-left:15px; border-top:1px solid #e0e0e0; border-bottom:1px solid #fff; font-family:微软雅黑; font-size:14px; cursor:default;}
.epMenu a:hover{ background:#fff;}

下面就是菜单的自定义调用部分了:

document.onmousedown = function(e){
    var menuNode=document.getElementById('epMenu');
    if(e.button===2){
      document.oncontextmenu = hideSysMenu;//屏蔽鼠标右键
      var evt = window.event || arguments[0];
      var rightedge = evt.clientX;
      var bottomedge = evt.clientY;
      epMenu.create({left:rightedge,top:bottomedge},[{name:'a1','action':sayhello},{name:'b2','action':sayhello},{name:'c3','action':sayhello},{name:'c4','action':sayhello}]);  
    }
//   epMenu.destory();
  }

简单解析一下:

1、epMenu.create方法的第一个参数是菜单弹出的位置坐标(距离屏幕左上角),这里用的是鼠标点击的坐标,菜单跟随鼠标点击弹出;第二个参数是一个json格式的数据,用于自定义菜单项,name是菜单项名字,action是点击菜单项后的动作(可以是函数,ajax请求等)。

2、e.button的值:2表示点击右键,0表示点击左键,4表示点击中键(ie),各浏览器的button值不同,此处仅以ie11作为参考。

3、注意在创建自定义菜单之前一定要屏蔽系统默认的右键菜单,非常重要!!!

最后,这个简易的右键菜单功能还有点瑕疵,右键菜单弹出后,不进行菜单项点击操作,菜单不会自动关闭,后期有空再完善吧。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript实例教程(19) 使用HoTMetal(4)
Dec 23 Javascript
JavaScript 实现模态对话框 源代码大全
May 02 Javascript
JS中批量给元素绑定事件过程中的相关问题使用闭包解决
Apr 15 Javascript
利用javaScript实现点击输入框弹出窗体选择信息
Dec 11 Javascript
删除javascript中注释语句的正则表达式
Jun 11 Javascript
用JavaScript实现页面重定向功能的教程
Jun 04 Javascript
jQuery解决$符号命名冲突
Jun 18 Javascript
AngularJS表达式讲解及示例代码
Aug 16 Javascript
微信小程序动态添加分享数据
Jun 14 Javascript
深入浅析Node环境和浏览器的区别
Aug 14 Javascript
layui--select使用以及下拉框实现键盘选择的例子
Sep 24 Javascript
使用 Jest 和 Supertest 进行接口端点测试实例详解
Apr 25 Javascript
vue 使用原生组件上传图片的实例
Sep 08 #Javascript
使用js和canvas实现时钟效果
Sep 08 #Javascript
javascript使用canvas实现饼状图效果
Sep 08 #Javascript
vue配置多代理服务接口地址操作
Sep 08 #Javascript
全局安装 Vue cli3 和 继续使用 Vue-cli2.x操作
Sep 08 #Javascript
JS删除对象中某一属性案例详解
Sep 08 #Javascript
vue全局使用axios的操作
Sep 08 #Javascript
You might like
php面向对象全攻略 (十一)__toString()用法 克隆对象 __call处理调用错误
2009/09/30 PHP
PHP strtotime函数用法、实现原理和源码分析
2015/02/04 PHP
Yii框架中sphinx索引配置方法解析
2016/10/18 PHP
php分页查询mysql结果的base64处理方法示例
2017/05/18 PHP
javascript之解决IE下不渲染的bug
2007/06/29 Javascript
javascript实现的像java、c#之类的sleep暂停的函数代码
2010/03/04 Javascript
js jquery数组介绍
2012/07/15 Javascript
JQuery记住用户名和密码的具体实现
2014/04/04 Javascript
javascript进行数组追加方法小结
2014/06/16 Javascript
原生JS实现图片轮播与淡入效果的简单实例
2016/08/21 Javascript
Javascript实现汉字和拼音互转的终极方案
2016/10/19 Javascript
前端 Vue.js 和 MVVM 详细介绍
2016/12/29 Javascript
js实现图片左右滚动效果
2017/02/27 Javascript
值得收藏的vuejs安装教程
2017/11/21 Javascript
Vue 中axios配置实例详解
2018/07/27 Javascript
vscode配置vue下的es6规范自动格式化详解
2019/03/20 Javascript
常见的浏览器存储方式(cookie、localStorage、sessionStorage)
2019/05/07 Javascript
关于JavaScript中异步/等待的用法与理解
2020/11/18 Javascript
Python 3.6 性能测试框架Locust安装及使用方法(详解)
2017/10/11 Python
python实现对指定输入的字符串逆序输出的6种方法
2018/04/26 Python
Python中的TCP socket写法示例
2018/05/11 Python
使用python爬取B站千万级数据
2018/06/08 Python
使用Python的OpenCV模块识别滑动验证码的缺口(推荐)
2019/05/10 Python
Python中的asyncio代码详解
2019/06/10 Python
PyQt5固定窗口大小的方法
2019/06/18 Python
Python爬虫程序架构和运行流程原理解析
2020/03/09 Python
Reebok俄罗斯官方网上商店:购买锐步运动服装和鞋子
2016/09/26 全球购物
美国在线乐器和设备商店:Musician’s Friend
2018/07/06 全球购物
Roxy俄罗斯官方网站:冲浪和滑雪板的一切
2020/06/20 全球购物
教育局长自荐信范文
2013/12/22 职场文书
创优争先心得体会
2014/09/11 职场文书
调研报告的主要写法
2019/04/18 职场文书
2019商业计划书格式、范文
2019/04/24 职场文书
Nginx进程管理和重载原理详解
2021/04/22 Servers
python和Appium的移动端多设备自动化测试框架
2022/04/26 Python
解决Mysql中的innoDB幻读问题
2022/04/29 MySQL