如何实现浏览器上的右键菜单


Posted in Javascript onJuly 10, 2006

 

 最近在程序员大本营中的讨论中有一位老兄提出如何在浏览器中实现类似于应用程序的鼠标右击后出现右键菜单的效果。唯鱼试了试,发现不是很难解决。现在就将源码和原理说出来和大家共享一下。哈,其实效果不是很完美啦,如果哪位大侠有更好的解决方法。可以给唯鱼yyu@enet.com.cn来信罗。 

首先要解决的问题是在怎样的情况鼠标右击不会出现IE的菜单。思路可以有两个,一个是将焦点移开,还有一个就是点在网页的什么地方不会出现右键菜单,而且会响应鼠标点击消息。(哈哈,废话一大堆。思路吗?总要多想想才有的) 

想了想, 总结出的下面几种方法
1、响应右键消息出一个ALERT框(还有点新鲜的东东没有)。 
2、响应右键消息后弹出一个新的窗口。将初始页的的焦点移开。 
可是经过试验后发现只有窗口出现在鼠标右击的位置时,才会没有浏览器的右键菜单出现。 
3、响应右键消息后弹出一个HTML的对话框。即使用showModalDialog来开启一个HTML对话框。使用这种方式可以让右键菜单不会出现。但是有一个问题是使用使用showModalDialog开启的对话框不会向使用Window.Open开启的对话框一样可以移出屏幕所在的范围。就是说始终可以看见有一个对话框出现在屏幕上。这条路也不能走了。 
4、呵呵,最后一招了,唯鱼偶尔发现在Select上进行鼠标右击或左击都不会有反应。那么如果每次鼠标都点在Select上,不就不会出现浏览器的右键菜单了。 

下面就是一个例子,感兴趣的可以把下面的拷贝成Test.html,就可以看看效果了。

< HTML> 

< title>VFish Test< /title> 

< script> 

var x, y; 

document.onmousemove=moveMouse 

document.onmousedown=click 

function moveMouse() 

Layer1.style.left = event.clientX - 2; 

Layer1.style.top = event.clientY - 2; 

function click() 

if (event.button==2) 

x = event.clientX; 

y = event.clientY; 

Layer1.style.visibility=""; 

window.setTimeout("showMenu();", 500); 

else 

HiddenPop(); 

PopMenu.style.visibility='hidden'; 

function showMenu() 

PopMenu.style.left = x- 2; 

PopMenu.style.top = y- 2; 

PopMenu.style.visibility=""; 

HiddenPop(); 

function HiddenPop() 

Layer1.style.visibility='hidden'; 

< /script> 

< BODY> 

在窗口中右击一下看看出什么:) 

< div id=Layer1 style="position:absolute; width:4px; height:4px; z-index:3; visibility: hidden"> 

< select style="width:4">< /select> 

< /div> 

< div id=PopMenu style="position:absolute; width:100px; height:100px; z-index:1; visibility: hidden"> 

< table border=2 width=100 > 

< TH align="center" color="sliver" onclick=""> 

唯鱼的菜单 

< /tH> 

< tr> 

< td> 

click it!:) 

< /td> 

< /tr> 

< /table> 

< /div> 

< /BODY> 

< /HTML>

Javascript 相关文章推荐
jQuery html()等方法介绍
Nov 18 Javascript
js获取当前select 元素值的代码
Apr 19 Javascript
jQuery客户端分页实例代码
Nov 18 Javascript
jQuery大于号(&gt;)选择器的作用解释
Jan 13 Javascript
AngularJS学习笔记之ng-options指令
Jun 16 Javascript
JavaScript 经典实例日常收集整理(常用经典)
Mar 30 Javascript
bootstrap flask登录页面编写实例
Nov 01 Javascript
vue通过路由实现页面刷新的方法
Jan 25 Javascript
node+koa2+mysql+bootstrap搭建一个前端论坛
May 06 Javascript
解决vue 子组件修改父组件传来的props值报错问题
Nov 09 Javascript
node.js使用yargs处理命令行参数操作示例
Feb 11 Javascript
浅谈JavaScript中this的指向问题
Jul 28 Javascript
载入进度条 效果
Jul 08 #Javascript
让广告代码不再影响你的网页加载速度
Jul 07 #Javascript
一段实时更新的时间代码
Jul 07 #Javascript
根据分辨率不同,调用不同的css文件
Jul 07 #Javascript
鼠标图片振动代码
Jul 06 #Javascript
显示、隐藏密码
Jul 01 #Javascript
让焦点自动跳转
Jul 01 #Javascript
You might like
PHP+MySQL投票系统的设计和实现分享
2012/09/23 PHP
php编译安装php-amq扩展简明教程
2016/06/25 PHP
详解Yii2 rules 的验证规则
2016/12/02 PHP
laravel 解决crontab不执行的问题
2019/10/22 PHP
Iframe 自适应高度并实时监控高度变化的js代码
2009/10/30 Javascript
div+css+js实现无缝滚动类似marquee无缝滚动兼容firefox
2013/08/29 Javascript
通过js获取div的background-image属性
2013/10/15 Javascript
浅谈Jquery为元素绑定事件
2015/04/27 Javascript
jQuery扩展实现text提示还能输入多少字节的方法
2016/11/28 Javascript
Angular X中使用ngrx的方法详解(附源码)
2017/07/10 Javascript
vue 2.0项目中如何引入element-ui详解
2017/09/06 Javascript
js+css实现打字效果
2020/06/24 Javascript
移动端如何用下拉刷新的方式实现上拉加载
2018/12/10 Javascript
JS为什么说async/await是generator的语法糖详解
2019/07/11 Javascript
Vue使用vue-draggable 插件在不同列表之间拖拽功能
2020/03/12 Javascript
谈谈JavaScript中的垃圾回收机制
2020/09/17 Javascript
如何使用原生Js实现随机点名详解
2021/01/06 Javascript
python类参数self使用示例
2014/02/17 Python
python从sqlite读取并显示数据的方法
2015/05/08 Python
Python中datetime模块参考手册
2017/01/13 Python
详谈Python高阶函数与函数装饰器(推荐)
2017/09/30 Python
Django项目中添加ldap登陆认证功能的实现
2019/04/04 Python
详解python持久化文件读写
2019/04/06 Python
如何基于Python + requests实现发送HTTP请求
2020/01/13 Python
Python+Kepler.gl实现时间轮播地图过程解析
2020/07/20 Python
HTML+CSS3 模仿Windows7 桌面效果
2010/06/17 HTML / CSS
纽约复古灵感的现代珠宝品牌:Lulu Frost
2018/03/03 全球购物
英国顶尖手表珠宝品牌独家授权经销商:HS Johnson
2020/10/28 全球购物
个性大学生自我评价
2013/12/04 职场文书
学校四群教育实施方案
2014/06/12 职场文书
领导干部整治奢华浪费之风思想汇报
2014/10/07 职场文书
时尚女魔头观后感
2015/06/04 职场文书
幼儿园师德师风心得体会
2016/01/12 职场文书
大学生心理健康教育心得体会
2016/01/12 职场文书
Pandas加速代码之避免使用for循环
2021/05/30 Python
Pytest中conftest.py的用法
2021/06/27 Python