js实现自定义右键菜单


Posted in Javascript onMay 18, 2020

本文实例为大家分享了js实现右键菜单的具体代码,供大家参考,具体内容如下

原理:

1.屏蔽默认的右键菜单

2.点击右键获取位置,让自定义菜单到点击位置上

3.点击左键,自定义菜单消失

代码如下

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>右键菜单练习</title>
 <style>
 *{
  margin: 0;
  /*padding: 0;*/
 }
 ul{
  width: 120px;
  height: 150px;
  background-color: rgb(204,204,204);
  font-size: 22px;
  list-style: none;
  line-height: 50px;
  position: fixed;
  display: none;
 }
 li{
  background-color: rgb(238,238,238);
  padding-left: 15px;
 }
 </style>
</head>
<body>
<ul id="ul">
 <li>复制</li>
 <li>剪切</li>
 <li>粘贴</li>
</ul>
<script>
 //给document 添加 oncontextmenu 事件 取消默认的右键菜单的行为。
 //点击右键的时候,获得点击的位置。
 var ul = document.getElementById('ul');
 document.oncontextmenu=function(e){
 e=e||window.event;
 //屏蔽样式
 e.preventDefault?e.preventDefault():(e.returnValue=false);
 //获取坐标
 var x=e.clientX;//视口的位置
 var y=e.clientY;

 //显示菜单
 ul.style.display='block';
 ul.style.top=y+'px';
 ul.style.left=x+'px';
 };
 //点击左键 自定义菜单消失
 document.onclick=function () {
 ul.style.display='none';
 };
 //给每个li添加 鼠标进入(onmouseover)和鼠标离开(onmouseout)的事件
 var lis = document.querySelectorAll('li');
 for (let i = 0; i < lis.length; i++) {
 lis[i].onmouseover=function () {
  lis[i].style.backgroundColor='rgb(204,204,204)';
 };
 lis[i].onmouseout=function () {
  lis[i].style.backgroundColor='rgb(238,238,238)';
 }
 }

</script>
</body>
</html>

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

Javascript 相关文章推荐
javascript 跳转代码集合
Dec 03 Javascript
JS中的substring和substr函数的区别说明
May 07 Javascript
jquery实现个人中心导航菜单效果和美观都非常不错
Sep 02 Javascript
jQuery中:password选择器用法实例
Jan 03 Javascript
JavaScript Math.ceil 方法(对数值向上取整)
Jan 09 Javascript
详解Bootstrap四种图片样式
Jan 04 Javascript
javascript实现随机显示星星特效
Jan 28 Javascript
Vue.js常用指令之循环使用v-for指令教程
Jun 27 Javascript
ES6学习教程之模板字符串详解
Oct 09 Javascript
angularJs中json数据转换与本地存储的实例
Oct 08 Javascript
小程序实现搜索框功能
Mar 26 Javascript
原生js实现弹幕效果
Nov 29 Javascript
微信小程序手动添加收货地址省市区联动
May 18 #Javascript
怎么理解wx.navigateTo的events参数使用详情
May 18 #Javascript
django简单的前后端分离的数据传输实例 axios
May 18 #Javascript
vue+koa2搭建mock数据环境的详细教程
May 18 #Javascript
Vue 基于 vuedraggable 实现选中、拖拽、排序效果
May 18 #Javascript
react 生命周期实例分析
May 18 #Javascript
react使用CSS实现react动画功能示例
May 18 #Javascript
You might like
ajax+php打造进度条代码[readyState各状态说明]
2010/04/12 PHP
php循环检测目录是否存在并创建(循环创建目录)
2011/01/06 PHP
使用php记录用户通过搜索引擎进网站的关键词
2014/02/13 PHP
php操作xml入门之xml标签的属性分析
2015/01/23 PHP
php压缩和解压缩字符串的方法
2015/03/14 PHP
laravel实现Auth认证,登录、注册后的页面回跳方法
2019/09/30 PHP
javascript XML数据显示为HTML一例
2008/12/23 Javascript
28个JS验证函数收集
2010/03/02 Javascript
jquery实现的元素的left增加N像素 鼠标移开会慢慢的移动到原来的位置
2010/03/21 Javascript
基于jquery的图片幻灯展示源码
2012/07/15 Javascript
贴近用户体验的Jquery日期、时间选择插件
2015/08/19 Javascript
jquery实现的点击翻书效果代码
2015/11/04 Javascript
js实现表单及时验证功能 用户信息立即验证
2016/09/13 Javascript
js事件源window.event.srcElement兼容性写法(详解)
2016/11/25 Javascript
js中int和string数据类型互相转化实例
2019/01/16 Javascript
详解iview的checkbox多选框全选时校验问题
2019/06/10 Javascript
jQuery操作事件完整实例分析
2020/01/10 jQuery
nuxt 页面路由配置,主页轮播组件开发操作
2020/11/05 Javascript
[01:04:01]2014 DOTA2华西杯精英邀请赛5 24 DK VS VG
2014/05/25 DOTA
[03:20]次级联赛厮杀超职业 现超级兵对拆世纪大战
2014/10/30 DOTA
python使用urllib模块和pyquery实现阿里巴巴排名查询
2014/01/16 Python
python实现socket客户端和服务端简单示例
2014/02/24 Python
非递归的输出1-N的全排列实例(推荐)
2017/04/11 Python
django输出html内容的实例
2018/05/27 Python
Django Rest framework之权限的实现示例
2018/12/17 Python
Pandas实现DataFrame按行求百分数(比例数)
2019/12/27 Python
详解python破解zip文件密码的方法
2020/01/13 Python
Python基于Tkinter编写crc校验工具
2020/05/06 Python
Keras中的两种模型:Sequential和Model用法
2020/06/27 Python
PyCharm配置anaconda环境的步骤详解
2020/07/31 Python
Parfumdreams芬兰:购买香水和化妆品
2021/02/13 全球购物
Final类有什么特点
2012/04/25 面试题
公共事业管理本科生求职信
2013/10/07 职场文书
汽车机修工岗位职责
2014/03/06 职场文书
运动会班级前导词
2015/07/20 职场文书
聊一聊Redis与MySQL双写一致性如何保证
2021/06/26 Redis