JavaScript实现点击自制菜单效果


Posted in Javascript onFebruary 02, 2021

本文实例为大家分享了JavaScript实现点击自制菜单效果的具体代码,供大家参考,具体内容如下

应用场景:当我们希望用户再点击右键的时候不希望弹出浏览器的默认菜单时,需要阻止浏览器默认行为,并执行我们想要的效果

第一种方式,通过创建元素的方式

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    body {
      height: 3000px;
    }
    
    .menu {
      width: 100px;
      height: 280px;
      background-color: red;
      position: absolute;
      left: 0;
      top: 0;
      display: none;
    }
  </style>
</head>

<body>
  <script>
    var Bon = true;
    var menu = null;
    document.oncontextmenu = function(event) {
      if (Bon) {
        menu = document.createElement("div");
        menu.classList.add("menu");
        document.body.appendChild(menu);
        menu.style.left = event.pageX + "px";
        menu.style.top = event.pageY + "px";
        menu.style.display = "block";
        Bon = false;
        event.preventDefault();
      } else {
        menu.style.left = event.pageX + "px";
        menu.style.top = event.pageY + "px";
        event.preventDefault();
      }
    }

    document.onmousedown = function(e) {
      if (e.button == 0) {
        var menu = document.querySelector(".menu");
        document.body.removeChild(menu);
        Bon = true;
      }
    }
  </script>
</body>

</html>

第二种:通过隐藏元素的方式

<div class="menu"></div>
 <script>
    var menu = document.querySelector(".menu");
    document.oncontextmenu = function(event) {
      menu.style.left = event.pageX + "px";
      menu.style.top = event.pageY + "px";
      menu.style.display = "block";
      event.preventDefault();
    }
    document.onmousedown = function(e) {
      if (e.button == 0) {
        menu.style.display = "none";
      }
    }
</script>

当我们点击右键时就不会弹出默认的菜单了,弹出了我设置的红框框。

JavaScript实现点击自制菜单效果

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

Javascript 相关文章推荐
javascript字典探测用户名工具
Oct 05 Javascript
分享33个jQuery与CSS3实现的绚丽鼠标悬停效果
Dec 15 Javascript
node.js中的require使用详解
Dec 15 Javascript
自己动手写的jquery分页控件(非常简单实用)
Oct 28 Javascript
基于js实现微信发送好友如何分享到朋友圈、微博
Nov 30 Javascript
Bootstrap+jfinal实现省市级联下拉菜单
May 30 Javascript
jQuery实现获取元素索引值index的方法
Sep 18 Javascript
jQuery.datatables.js插件用法及api实例详解
Oct 28 Javascript
javascript 判断当前浏览器版本并判断ie版本
Feb 17 Javascript
深入浅出es6模板字符串
Aug 26 Javascript
vue 之 css module的使用方法
Dec 04 Javascript
vux-scroller实现移动端上拉加载功能过程解析
Oct 08 Javascript
Vue项目打包部署到apache服务器的方法步骤
Feb 01 #Vue.js
如何在vue中使用video.js播放m3u8格式的视频
Feb 01 #Vue.js
Vue 实现可视化拖拽页面编辑器
Feb 01 #Vue.js
vue-video-player 断点续播的实现
Feb 01 #Vue.js
Element el-button 按钮组件的使用详解
Feb 01 #Javascript
js实现简单商品筛选功能
Feb 02 #Javascript
如何在现代JavaScript中编写异步任务
Jan 31 #Javascript
You might like
php根据分类合并数组的方法实例详解
2013/11/06 PHP
编写PHP脚本来实现WordPress中评论分页的功能
2015/12/10 PHP
php中的常用魔术方法汇总
2016/02/14 PHP
PHP实现的XML操作类【XML Library】
2016/12/29 PHP
PHP开发实现快递查询功能详解
2019/04/08 PHP
JavaScript新窗口与子窗口传值详解
2014/02/11 Javascript
js自动查找select下拉的菜单并选择(示例代码)
2014/02/26 Javascript
JavaScript中的call方法和apply方法使用对比
2015/08/12 Javascript
JavaScript jQuery 中定义数组与操作及jquery数组操作
2015/12/18 Javascript
JavaScript常用本地对象小结
2016/03/28 Javascript
js判断手机号是否正确并返回的实现代码
2017/01/17 Javascript
Ionic + Angular.js实现图片轮播的方法示例
2017/05/21 Javascript
详解用webpack的CommonsChunkPlugin提取公共代码的3种方式
2017/11/09 Javascript
基于vue-element组件实现音乐播放器功能
2018/05/06 Javascript
详解JavaScript中操作符和表达式
2018/09/12 Javascript
Vuex的热更替如何实现
2020/06/05 Javascript
详解vue组件之间的通信
2020/08/30 Javascript
[05:08]第一届“网鱼杯”DOTA2比赛精彩集锦
2014/09/05 DOTA
在Python下进行UDP网络编程的教程
2015/04/29 Python
Python NumPy库安装使用笔记
2015/05/18 Python
Python字符串拼接、截取及替换方法总结分析
2016/04/13 Python
Python matplotlib画曲线例题解析
2020/02/07 Python
python+selenium定时爬取丁香园的新型冠状病毒数据并制作出类似的地图(部署到云服务器)
2020/02/09 Python
Python  word实现读取及导出代码解析
2020/07/09 Python
详解Python高阶函数
2020/08/15 Python
python 录制系统声音的示例
2020/12/21 Python
HTML5 使用 sessionStorage 进行页面传值的方法
2018/07/02 HTML / CSS
html5 application cache遇到的严重问题
2012/12/26 HTML / CSS
澳大利亚在线时尚精品店:Hello Molly
2018/02/26 全球购物
乌克兰时尚鞋子和衣服购物网站:Born2be
2018/05/24 全球购物
PHP面试题-$message和$$message的区别
2015/12/08 面试题
综合素质的自我鉴定
2013/10/07 职场文书
施工资料员的岗位职责
2013/12/22 职场文书
班主任班级寄语大全
2014/04/04 职场文书
2014年人民警察入党思想汇报
2014/10/12 职场文书
小学科学课教学反思
2016/02/23 职场文书