javascript实例 实现浏览器上的右键菜单
|
最近在程序员大本营中的讨论中有一位老兄提出如何在浏览器中实现类似于应用程序的鼠标右击后出现右键菜单的效果。唯鱼试了试,发现不是很难解决。现在就将源码和原理说出来和大家共享一下。哈,其实效果不是很完美啦,如果哪位大侠有更好的解决方法。 可以给唯鱼yyu@enet.com.cn来信罗。 首先要解决的问题是在怎样的情况鼠标右击不会出现IE的菜单。思路可以有两个,一个是将焦点移开,还有一个就是点在网页的什么地方不会出现右键菜单,而且会响应鼠标点击消息。(哈哈,废话一大堆。思路吗?总要多想想才有的)
下面就是一个例子,感兴趣的可以把下面的拷贝成Test.html,就可以看看效果了。
< title>VFish Test< /title> < script> var x, y; document.onmousemove=moveMouse document.onmousedown=click
{ 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>
源代码网供稿. |
