This Domain(Admin5.com) is for Sale:

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

时间:2007-12-27  来源:不详  作者:林子

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

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

织梦好,好织梦

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

想了想, 总结出的下面几种方法

dedecms.com

1、响应右键消息出一个ALERT框(还有点新鲜的东东没有)。

织梦内容管理系统

2、响应右键消息后弹出一个新的窗口。将初始页的的焦点移开。

本文来自织梦

可是经过试验后发现只有窗口出现在鼠标右击的位置时,才会没有浏览器的右键菜单出现。

内容来自dedecms

3、响应右键消息后弹出一个HTML的对话框。即使用showModalDialog来开启一个HTML对话框。使用这种方式可以让右键菜单不会出现。但是有一个问题是使用使用showModalDialog开启的对话框不会向使用Window.Open开启的对话框一样可以移出屏幕所在的范围。就是说始终可以看见有一个对话框出现在屏幕上。这条路也不能走了。 copyright dedecms

4、呵呵,最后一招了,唯鱼偶然发现在Select上进行鼠标右击或左击都不会有反应。那么假如每次鼠标都点在Select上,不就不会出现浏览器的右键菜单了。

copyright dedecms

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

< HTML> 内容来自dedecms

< title>VFish Test< /title>

内容来自dedecms

< script> 内容来自dedecms

var x, y;

织梦内容管理系统

document.onmousemove=moveMouse dedecms.com

document.onmousedown=click 织梦好,好织梦


function moveMouse()

内容来自dedecms

{

织梦好,好织梦

Layer1.style.left = event.clientX - 2; 织梦内容管理系统

Layer1.style.top = event.clientY - 2; 织梦好,好织梦

} dedecms.com

function click()

copyright dedecms

{

copyright dedecms

if (event.button==2)

本文来自织梦

{

织梦好,好织梦

x = event.clientX;

织梦内容管理系统

y = event.clientY;

dedecms.com

Layer1.style.visibility="";

本文来自织梦

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

本文来自织梦

} dedecms.com

else

内容来自dedecms

{ dedecms.com

HiddenPop(); 织梦好,好织梦

PopMenu.style.visibility=’hidden’;

dedecms.com

}

织梦内容管理系统


} 织梦内容管理系统

function showMenu()

本文来自织梦

{ copyright dedecms

PopMenu.style.left = x- 2;

本文来自织梦

PopMenu.style.top = y- 2; 织梦好,好织梦

PopMenu.style.visibility="";

内容来自dedecms

HiddenPop(); 织梦好,好织梦

}

内容来自dedecms

function HiddenPop()

dedecms.com

{ copyright dedecms

Layer1.style.visibility=’hidden’; dedecms.com

} 织梦好,好织梦

< /script> dedecms.com

< BODY>

本文来自织梦


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

dedecms.com

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

copyright dedecms

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

本文来自织梦

< /div>

copyright dedecms

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

dedecms.com

< table border=2 width=100 > 织梦内容管理系统

< TH align="center" color="sliver" onclick=""> 内容来自dedecms

唯鱼的菜单 织梦好,好织梦

< /tH>

copyright dedecms

< tr>

织梦内容管理系统

< td> 本文来自织梦

click it!:) copyright dedecms

< /td> 织梦好,好织梦

< /tr>

织梦好,好织梦

< /table>

看完这篇,您有何感觉呢?

文章评论

共有位Admini5网友发表了评论 查看完整内容

24小时热门信息