- 热门文章:
- · javascript进行客户端数据的校验
- · 首页地址添加到收藏夹(javascript)
- · 利用JAVASCRIPT制作简单动画
- · 在IE中使用JavaScript
- · Javascript模拟游戏中的弹出菜单效果
- · Javascript制作闪烁的边框
- · Javascript设计漫天雪花
- · Javascript实例教程(20) OLE Automation(7)
- · Javascript实例教程(20) OLE Automation(6)
- · Javascript实例教程(20) OLE Automation(5)
- · Javascript实例教程(20) OLE Automation(4)
- · Javascript实例教程(20) OLE Automation(3)
上一篇:用JavaScript使链接按钮不断变化 >>
javascript中如何实现浏览器上的右键菜单
最近在程序员大本营中的讨论中有一位老兄提出如何在浏览器中实现类似于应用程序的鼠标右击后出现右键菜单的效果。唯鱼试了试,发现不是很难解决。现在就将源码和原理说出来和大家共享一下。哈,其实效果不是很完美啦,如果哪位大侠有更好的解决方法。可以给唯鱼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进行客户端数据的校验 >>
相关文章:
- · Javascript实例教程(20) OLE Automation(2)
- · Javascript实例教程(20) OLE Automation(1)
- · Javascript实例教程(20) OLE Automation(1)
- · Javascript实例教程(19) 使用HoTMetal(7)
- · Javascript实例教程(19) 使用HoTMetal(6)
- · Javascript实例教程(19) 使用HoTMetal(5)
- · Javascript实例教程(19) 使用HoTMetal(4)
- · Javascript实例教程(19) 使用HoTMetal(3)
- · Javascript实例教程(19) 使用HoTMetal(2)
- · Javascript实例教程(19) 使用HoTMetal(1)
- · Javascript实例教程(18) 数组
- · Javascript实例教程(14) JS代替CGI
- · Javascript实例教程(13) 鼠标触发窗口
- · Javascript实例教程(12) 鼠标移过时报警
- · Javascript实例教程(11) 隐藏script代码
- · Javascript实例教程(10) 创建"后退"按钮
- · Javascript实例教程(9) 随机显示图片
- · Javascript实例教程(8) 检验表单有效性
- · Javascript实例教程(7) 利用Javascript基于浏览器类型的重定向
- · Javascript实例教程(6) 利用Javascript进行密码保护
- · Javascript实例教程(5) 在一个表单中设置和检查Cookies
- · Javascript实例教程(3) 探测浏览器插件
- · Javascript实例教程(2) 创建折叠式导航菜单
- · Javascript实例教程(1) 创建弹出式窗口
- · JS实现身份证号码15位转18位时最后一位的算法
- · 如何用Javascript获得TextArea中的光标位置
- · 张孝祥JavaScript教程笔记:HTML基础(三)-URL,图像标签,图像地图
- · 限制图片上传长宽的JavaScript代码
- · 判断输入框中的小数点问题
- · 判断输入框中的小数点问题
- · 实用函数:判断输入的是否是电话号码
- · 网页之定时器详解
- · 张孝祥JavaScript教程笔记:HTML基础(二)
- · 用网页代码实现把TAB键变为Enter键
- · 张孝祥JavaScript教程笔记:HTML基础
- · Javascript控制XSlt转换XML
- · 弹出新窗口,填写数据,提交后,关闭该弹出窗口,刷新父页面
- · 无限分类算法 js 的实现
